@import"https://fonts.googleapis.com/css2?family=Syne:wght@700;800&family=Work+Sans:wght@300;400;500;600&display=swap";:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}:root{--bg-dark: #1a1d24;--card-bg: #2c313a;--card-bg-transparent: #2c313ac5;--card-border: #2c313a;--modal-blur-bg: rgba(31, 33, 41, .9);--text-main: #f8fafc;--text-dim: #94a3b8;--accent-dev: #869ea8;--accent-game: #f3a040;--badge-bg-dev: rgba(36, 119, 155, .1);--badge-bg-game: rgba(247, 209, 103, .1);--font-header: "Syne", sans-serif;--font-body: "Work Sans", sans-serif}html{scroll-behavior:smooth}main{flex:1}body{margin:0;min-height:100vh;color:var(--text-main);font-family:Inter,sans-serif;display:block;overflow-x:hidden;font-family:var(--font-body);-webkit-font-smoothing:antialiased}body:before{content:"";position:fixed;top:0;left:0;width:100%;height:110vh;background:linear-gradient(to bottom,#1a1d2466,#1a1d24e6),url(/images/portfoliobg1.jpg);background-size:cover;background-position:center;z-index:-1;will-change:transform;transform:translateY(clamp(-10vh,calc(var(--scroll-offset, 0px) * -.1),0px))}.icon-github{width:18px;height:18px;background-color:currentColor;mask:url(/github-mark-white.svg) no-repeat center / contain;-webkit-mask:url(/github-mark-white.svg) no-repeat center / contain}.icon-itchio{width:18px;height:18px;background-color:currentColor;mask:url(/itchio-logo-textless-white.svg) no-repeat center / contain;-webkit-mask:url(/itchio-logo-textless-white.svg) no-repeat center / contain}.main-title{font-size:3.5rem;margin-top:4rem;margin-bottom:.5rem;cursor:pointer;color:var(--text-main);text-shadow:0 0 15px rgba(255,255,255,.3);transition:transform .3s ease;font-family:var(--font-header);font-weight:400}.main-title:hover{transform:scale(1.02)}h1,h2,h3,.cv-title,.timeline-category{font-family:var(--font-header);font-weight:700}p,.modal-desc,.timeline-content{font-family:var(--font-body);font-weight:400;line-height:1.7;letter-spacing:.01rem}.tech-badge,.btn-primary,.btn-secondary,.nav-button{font-family:var(--font-body);font-weight:600;font-size:.85rem;letter-spacing:.05rem}.inline-link{color:var(--accent-dev);text-decoration:none;cursor:pointer;font-weight:700;transition:all .2s ease;margin-right:0;display:inline;border-bottom:2px solid var(--accent-dev)}.inline-link:hover{color:var(--text-main);background:#38bdf81a;border-radius:4px}.app-container{background:transparent;min-height:100vh;width:100%;max-width:1200px;display:flex;flex-direction:column;align-items:center;padding:0 2rem;text-align:center;box-sizing:border-box;margin:0 auto;overflow-x:hidden}header{width:100%;display:flex;flex-direction:column;align-items:center;margin-bottom:2rem;background:transparent;z-index:10}nav{display:flex;justify-content:center;align-items:center;gap:3rem;width:fit-content;max-width:90vw;margin:1.5rem auto 3rem;padding:.8rem 2.5rem;border-bottom:1px solid rgba(255,255,255,.1);background:var(--card-bg-transparent);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:20px;border:1px solid rgba(255,255,255,.1);flex-shrink:0;box-shadow:0 4px 15px #0003;box-sizing:border-box}nav button{background:none!important;border:none!important;color:var(--text-dim);font-size:.95rem;font-weight:600;padding:.5rem 0;cursor:pointer;position:relative;text-transform:uppercase;letter-spacing:1px;white-space:nowrap;text-shadow:0 0 5px rgba(0,0,0,.9);transition:color .3s ease,text-shadow .3s ease}nav button:hover{color:var(--text-main);background:none}nav button:hover,nav button.active{text-shadow:0 0 10px rgba(255,255,255,.2),0 2px 4px rgba(0,0,0,.8)}nav button:after{content:"";position:absolute;bottom:-.9rem;left:0;width:0;height:4px;background-color:var(--accent-dev);transition:width .3s ease}nav button.active[data-view=game]{text-shadow:0 0 12px rgba(247,189,103,.5),0 2px 4px rgba(0,0,0,.8)}nav button.active[data-view=game]:after{background-color:var(--accent-game)}nav button.active{color:var(--text-main);background:none}nav button.active:after{width:100%}nav button+button{position:relative}nav button+button:before{content:"";position:absolute;left:-1.5rem;top:50%;transform:translateY(-50%);width:1px;height:1.2rem;background:#ffffff26}button{background:var(--card-bg);color:var(--text-main);border:1px solid #334155;padding:.6rem 1.2rem;border-radius:8px;cursor:pointer;transition:all .2s ease;white-space:nowrap}button.active{border-color:var(--accent-dev);background:#38bdf81a;color:var(--accent-dev)}.content-area{width:100%;display:flex;flex-direction:column;align-items:center;flex:1}.about-section{max-width:800px;border-radius:20px;margin:2rem auto;background:var(--card-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:3rem;text-align:center;box-sizing:border-box;overflow:hidden;box-shadow:0 10px 25px #0000004d}.cv-section{width:90%;max-width:800px;margin:2rem auto;background:var(--card-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;padding:3rem;text-align:center;box-sizing:border-box;overflow:hidden;box-shadow:0 10px 25px #0000004d}.cv-section,.about-section,.projects-grid{width:100%;max-width:100%}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:2rem;width:100%;max-width:1400px;justify-content:center;margin:0 auto}.project-card,.text-card{background:var(--card-bg);border-radius:12px;overflow:hidden;transition:transform .3s ease,box-shadow .3s ease;border:1px solid var(--card-border);display:flex;flex-direction:column;text-align:left;cursor:pointer}.project-card,.text-card,.cv-section,.about-section{background:#2c313acc!important;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1)}.card-image-container{width:100%;height:200px;flex-shrink:0;object-fit:cover;display:block;animation:simpleFade .4s ease-in}.card-image-container img{width:100%;height:100%;object-fit:cover;display:block}.card-content{padding:1.5rem}.card-content h3{line-height:1.1;margin-bottom:.5rem;font-size:1.4rem}.dev-card{border-top:4px solid var(--accent-dev)}.game-card{border-top:4px solid var(--accent-game)}.project-card:hover{transform:translateY(-8px);box-shadow:0 12px 30px #0006}.tech-stack{display:flex;flex-wrap:wrap;gap:.5rem;margin:1rem 0}.tech-badge{background:var(--badge-bg-dev);color:var(--accent-dev);border:1px solid var(--accent-dev);padding:.4rem .8rem;border-radius:6px;font-size:.85rem;font-weight:500;white-space:nowrap}.modal-header{display:flex;justify-content:space-between;align-items:center;gap:2rem;margin-bottom:1.5rem;flex-wrap:wrap}.modal-header h2{margin:0;flex:1}.modal-actions{display:flex;gap:1rem;margin-top:0!important}.modal-actions a{display:inline-flex!important;flex-direction:row!important;align-items:center;justify-content:center;gap:10px;padding:.6rem 1.2rem;text-decoration:none;border-radius:8px;font-size:.9rem;white-space:nowrap}.modal-actions a svg{display:block;flex-shrink:0}.modal-actions a:hover svg{transform:translateY(-2px)}.modal-tech{display:flex;flex-wrap:wrap;gap:12px;margin:1.5rem 0}.modal-tech .tech-badge{padding:6px 12px;display:inline-block;background:var(--badge-bg-dev);border-radius:6px;font-size:.85rem;line-height:1}.games-grid .tech-badge,.game-modal .tech-badge{background:var(--badge-bg-game);color:var(--accent-game);border:1px solid var(--accent-game)}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:var(--modal-blur-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);display:flex;justify-content:center;align-items:center;z-index:1000;padding:20px}.modal-content{position:relative;background:var(--card-bg);padding:0;border-radius:20px;max-width:850px;width:90%;max-height:85vh;overflow:hidden;display:flex;flex-direction:column;text-align:left;box-sizing:border-box}.modal-scroll-area{padding:2.5rem 3rem;overflow-y:auto;flex:1}.modal-fade-bottom{position:absolute;bottom:0;left:0;width:100%;height:80px;background:linear-gradient(to top,var(--card-bg) 30%,transparent);pointer-events:none;z-index:1010;border-bottom-left-radius:20px;border-bottom-right-radius:20px}.modal-scroll-area:after{content:"";display:block;height:40px}.modal-content::-webkit-scrollbar{width:8px}.modal-content::-webkit-scrollbar-track{background:transparent}.modal-content::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:10px}.modal-content::-webkit-scrollbar-thumb:hover{background:var(--accent-dev)}.modal-content a{color:var(--accent-dev);text-decoration:none;font-weight:600;margin-top:1rem;display:inline-block;transition:opacity .2s}.modal-content a:hover{color:var(--text-main);text-decoration:underline}.modal-img{width:100%;max-height:400px;object-fit:cover;border-radius:12px;margin:0 0 1.5rem;display:block}.btn-primary{background:var(--accent-dev);color:#1a1d24!important}.btn-secondary{background:var(--accent-game);color:var(--card-bg)!important}.close-btn{position:absolute;top:1.5rem;right:1.5rem;z-index:1020;width:32px;height:32px;background:var(--card-bg-transparent);border-radius:50%;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.close-btn:before,.close-btn:after{content:"";position:absolute;width:20px;height:2px;background-color:var(--text-dim);border-radius:2px;transition:background-color .2s ease}.close-btn:before{transform:rotate(45deg)}.close-btn:after{transform:rotate(-45deg)}.close-btn:hover{transform:rotate(90deg)}.close-btn:hover:before,.close-btn:hover:after{background-color:#ff4d4d}.download-btn{display:inline-flex;margin-top:2rem;align-items:center;justify-content:center;gap:12px;padding:.8rem 0rem;color:var(--accent-dev);background:transparent;border-radius:8px;text-decoration:none;font-family:var(--font-header);font-weight:700;transition:all .3s ease;cursor:pointer}.download-btn:hover{transform:translateY(-3px);color:var(--text-main)}.download-btn .btn-icon{width:20px;height:20px;transform:translateY(-1px);background-color:var(--accent-dev);mask:url(/download.svg) no-repeat center / contain;-webkit-mask:url(/download.svg) no-repeat center / contain;transition:background-color .3s ease}.download-btn:hover .btn-icon{background-color:var(--text-main)}.footer{width:100%;padding:4rem 0 2rem;margin-top:2rem;border-top:1px solid rgba(255,255,255,.05)}.footer-icon{width:24px;height:24px;opacity:.6;transition:all .3s ease}.footer-links a:hover .footer-icon{opacity:1;transform:translateY(-3px);filter:drop-shadow(0 0 8px var(--accent-dev))}.footer p{font-size:.8rem;color:var(--text-dim);letter-spacing:1px}.footer-content{max-width:1200px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:1.5rem;color:var(--text-dim);font-size:.9rem}.footer-links{display:flex;gap:2rem}.footer-links a{color:var(--text-dim);text-decoration:none;transition:color .2s ease}.footer-links a:hover{color:var(--text-main)}.cv-timeline{position:relative;max-width:700px;margin:2rem auto;text-align:left;padding-left:20px}.cv-timeline:before{content:"";position:absolute;left:.18rem;top:0;bottom:0;width:2px;background:#ffffff1a}.timeline-category{color:var(--accent-dev);text-transform:uppercase;font-size:1rem;letter-spacing:2px;margin:2rem 0 1.5rem;padding:5px 10px;display:inline-block;border-radius:4px}.timeline-item{position:relative;margin-bottom:2.5rem}.timeline-dot{position:absolute;left:-24px;top:6px;width:10px;height:10px;border-radius:50%;background:var(--accent-dev);border:3px solid var(--card-bg);z-index:2}.timeline-content h4{color:var(--text-dim);font-size:.85rem;margin:0 0 .5rem}.timeline-content h5{font-size:1.1rem;color:var(--text-main);margin:0 0 .5rem}.timeline-content ul{list-style:none;padding:0;margin:.8rem 0 0}.timeline-content li{position:relative;padding-left:1.5rem;margin-bottom:.5rem;color:var(--text-dim);font-size:.95rem;line-height:1.5;transition:transform .2s ease,color .2s ease}.timeline-content li:before{content:"•";position:absolute;left:0;color:var(--accent-dev);font-weight:700;font-size:1.2rem;line-height:1.6rem}.timeline-item:hover .timeline-dot{background:var(--accent-game);box-shadow:0 0 10px var(--accent-game);transform:scale(1.2);border-color:var(--text-main);transition:all .3s ease}.timeline-item:hover .timeline-content h5,.timeline-item:hover .timeline-content h4{color:var(--accent-game);transition:color .3s ease}.timeline-item:hover:after{opacity:.5}.timeline-item:last-child:after{display:none}.timeline-item:hover li{color:var(--text-main);transform:translate(5px)}.skills-container{margin-top:1rem;padding-top:1rem;margin-bottom:1rem;padding-bottom:3rem;border-top:1px solid rgba(255,255,255,.05);border-bottom:1px solid rgba(255,255,255,.05)}.skills-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:2rem;margin-top:1.5rem;text-align:left}.skill-group h4{color:var(--text-main);font-size:.9rem;margin-bottom:1rem;text-transform:uppercase;letter-spacing:1px}.skill-badges{display:flex;flex-wrap:wrap;gap:.8rem}.skill-badge{padding:.5rem .8rem;border-radius:6px;font-size:.85rem;font-weight:500;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);transition:all .3s ease}.skill-badge.game:hover{border-color:var(--accent-game);color:var(--accent-game);background:var(--badge-bg-game)}.skill-badge.dev:hover{border-color:var(--accent-dev);color:var(--accent-dev);background:var(--badge-bg-dev)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.fade-wrapper{animation:fadeIn .4s ease-out forwards;width:100%}.content-area{min-height:60vh}@keyframes cardPop{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.animate-card{opacity:0;animation:cardPop .5s ease-out forwards;animation-delay:calc(var(--stagger) * .1s)}@media(max-width:768px){.main-title{font-size:2.2rem;margin-top:2rem}.app-container{padding:0 15px}.about-section{padding:0 1.5rem;text-align:center}.projects-grid{grid-template-columns:1fr!important;width:100%;padding:10px;box-sizing:border-box;gap:20px}.project-card{width:100%!important;max-width:100%;margin:0;box-sizing:border-box}nav{gap:1rem;padding:.6rem 1.2rem;width:95%;margin:1rem auto 2rem;flex-wrap:nowrap;justify-content:space-evenly}nav button{font-size:.8rem;letter-spacing:.5px}nav button:after{bottom:-.75rem}nav button+button:before{left:-1rem}.separator-line{width:90%!important}.modal-content{padding:3rem 1.5rem 2rem;width:95%}.close-btn{top:1rem;right:1rem}.cv-section{padding:1rem;width:100%;box-sizing:border-box}.cv-grid,.experience-item{display:flex;flex-direction:column;gap:10px}.download-btn{display:block;width:100%;text-align:center;box-sizing:border-box}.footer-links{gap:1.5rem}.modal-header{flex-direction:column;align-items:flex-start;gap:1rem}.modal-actions{flex-direction:column;width:100%;justify-content:flex-start}.modal-actions a{width:100%;box-sizing:border-box}}
