:root{font-family:"Inter",system-ui,;line-height:1.6;font-weight:600;color:var(--color-white);background-color:var(--color-black);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html[data-theme=light]{--color-black: #ffffff;--color-dark-grey: #161616;--color-grey: #575757e8;--color-light-grey: #f1f1f1dc;--color-white: #212529;--color-blue: #4781ff;--color-blue-hover: #1746a2;background-color:var(--color-black);color:var(--color-white)}html[data-theme=dark]{--color-black: #0a0a0a;--color-dark-grey: #f0f0f0;--color-grey: #797979ef;--color-light-grey: #464646c4;--color-white: #ffffff;--color-blue: #3b82f6;--color-blue-hover: #2563eb;background-color:var(--color-black);color:var(--color-white)}html[data-theme=light] .navbar{background-color:#e9ecef!important;border-bottom:1px solid #dee2e6!important}html[data-theme=light] .nav-link,html[data-theme=light] .nav-logo,html[data-theme=light] .nav-resume-btn{color:#212529!important}html[data-theme=light] .nav-link:hover{color:var(--color-blue)!important}*{margin:0;padding:0;box-sizing:border-box}html,body{width:100%;max-width:100vw}body{background-color:var(--color-black);color:var(--color-white);overflow-x:hidden;width:100%;max-width:100vw;overflow-y:auto}p{font-family:system-ui;font-style:normal;font-weight:350}#app{overflow:visible;height:auto}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-light-grey);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--color-blue)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes revealFromBottom{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.section-reveal{opacity:0;transform:translateY(60px);transition:all .8s cubic-bezier(.25,.46,.45,.94)}.section-reveal.revealed{opacity:1;transform:translateY(0)}.stagger-children>*{opacity:0;transform:translateY(10px);transition:all .6s cubic-bezier(.25,.46,.45,.94)}.section-reveal.revealed .stagger-children>*{opacity:1;transform:translateY(0)}.stagger-children>*:nth-child(1){transition-delay:.1s}.stagger-children>*:nth-child(2){transition-delay:.2s}.stagger-children>*:nth-child(3){transition-delay:.3s}.stagger-children>*:nth-child(4){transition-delay:.4s}.stagger-children>*:nth-child(5){transition-delay:.5s}.stagger-children>*:nth-child(6){transition-delay:.6s}.nav-link.active{color:var(--color-blue)!important}.nav-link.active:before{width:100%!important}.fade-in-up{animation:fadeInUp .8s ease-out forwards}@media (max-width: 768px){.fade-in-up{animation:none;opacity:1;transform:none}.section-reveal{opacity:1;transform:none;transition:none}.section-reveal.revealed{opacity:1;transform:none}.stagger-children>*{opacity:1;transform:none;transition:none}.section-reveal.revealed .stagger-children>*{opacity:1;transform:none}}.navbar[data-v-875b52ab]{position:fixed;display:flex;top:0;left:0;right:0;z-index:1000;background-color:var(--color-light-grey);transition:all .3s ease-in-out;justify-content:center;gap:18rem;padding:.25rem;width:100%;margin:0}.nav-container[data-v-875b52ab]{display:flex;align-items:center;height:70px}.nav-logo[data-v-875b52ab]{text-decoration:none;color:var(--color-white);font-size:1.4rem;font-weight:700;transition:all .3s ease}.nav-logo[data-v-875b52ab]:hover{color:var(--color-blue);transform:scale(1.05)}.logo-text[data-v-875b52ab]{position:relative}.logo-text[data-v-875b52ab]:after{content:"";position:absolute;bottom:-2px;left:0;width:0;height:2px;background-color:var(--color-blue);transition:width .3s ease}.nav-logo:hover .logo-text[data-v-875b52ab]:after{width:100%}.nav-menu[data-v-875b52ab]{display:flex;gap:2.5rem;align-items:center;justify-content:center;margin:1rem}.nav-link[data-v-875b52ab]{text-decoration:none;color:var(--color-white);font-weight:500;font-size:1.1rem;position:relative;transition:all .3s ease}.nav-link[data-v-875b52ab]:before{content:"";position:absolute;bottom:0;left:50%;width:0;height:2px;background-color:var(--color-blue);transition:all .3s ease;transform:translate(-50%)}.nav-link[data-v-875b52ab]:hover,.nav-link.active[data-v-875b52ab]{color:var(--color-blue)}.nav-link[data-v-875b52ab]:hover:before,.nav-link.active[data-v-875b52ab]:before{width:100%}.social-links[data-v-875b52ab]{display:none;justify-content:center;height:1rem;border:none;border-left:.1rem solid var(--color-white);border-right:.1rem solid var(--color-white)}.nav-contact[data-v-875b52ab]{display:flex;align-items:center;gap:1.5rem}.nav-icon[data-v-875b52ab]{color:var(--color-white);display:flex;align-items:center;padding:.5rem;border-radius:6px;transition:all .3s ease}.nav-icon[data-v-875b52ab]:hover{background-color:var(--color-blue);color:var(--color-white);transform:translateY(-2px)}.nav-resume-btn[data-v-875b52ab]{display:flex;position:relative;overflow:hidden;justify-content:right;align-items:center;text-decoration:none;margin:.5rem;padding:.75rem 1.25rem;color:var(--color-blue);border-radius:.5rem;border:.15rem solid var(--color-blue);font-weight:600;font-size:.9rem;background-color:transparent;transition:all .3s ease-out}.nav-resume-btn[data-v-875b52ab]:hover{scale:1.1;background-color:var(--color-blue);border-radius:.25rem;color:var(--color-white)}.resume-text[data-v-875b52ab]{font-weight:700}.hamburger[data-v-875b52ab]{display:none;flex-direction:column;cursor:pointer;align-items:center;justify-content:center;margin:1rem}.hamburger span[data-v-875b52ab]{width:25px;height:2px;background-color:var(--color-white);margin:3px 0;transition:all .3s ease}.hamburger.active span[data-v-875b52ab]:nth-child(1){transform:rotate(45deg) translate(5px,5px)}.hamburger.active span[data-v-875b52ab]:nth-child(2){opacity:0}.hamburger.active span[data-v-875b52ab]:nth-child(3){transform:rotate(-45deg) translate(7px,-6px)}@media (max-width: 900px){.navbar[data-v-875b52ab]{justify-content:space-between;gap:1rem;margin:0;padding:0}.hamburger[data-v-875b52ab]{display:flex}.nav-menu[data-v-875b52ab]{margin:0;width:100%;height:100%;opacity:0;position:fixed;top:calc(60px - 110%);background-color:var(--color-black);flex-direction:column;justify-content:center;align-items:center;transition:all .3s ease-in-out;gap:1.5rem;left:0;right:0}.nav-menu.active[data-v-875b52ab]{top:78px;left:0;right:0;bottom:0;opacity:1}.social-links[data-v-875b52ab]{display:flex;border:none;border-top:.1rem solid var(--color-white)}.nav-link[data-v-875b52ab]{font-size:1.1rem;padding:1rem 0}.nav-contact[data-v-875b52ab]{margin-top:1rem;margin-left:0;padding-left:0;border-left:none;gap:1.5rem}.nav-icon[data-v-875b52ab]{padding:.75rem}.nav-resume-btn[data-v-875b52ab]{margin-left:1rem;margin-top:1rem;align-self:flex-end}}@media (max-width: 600px){.navbar[data-v-875b52ab]{gap:.5rem;padding:.25rem}.nav-resume-btn[data-v-875b52ab]{margin-left:.5rem;margin-top:.5rem;padding:.5rem 1rem;font-size:.8rem}}.theme-switcher-footer{position:fixed;right:2rem;bottom:2rem;z-index:2000;pointer-events:none}.theme-toggle-btn{pointer-events:auto;background:var(--color-light-grey);border:2px solid var(--color-grey);color:var(--color-white);border-radius:50%;width:56px;height:56px;display:flex;align-items:center;justify-content:center;font-size:2rem;cursor:pointer;box-shadow:0 4px 16px #00000026;transition:background .3s,border-color .3s,color .3s,transform .2s}.theme-toggle-btn:hover{background:var(--color-blue);color:var(--color-white);border-color:var(--color-blue);transform:scale(1.08)}.theme-icon{display:flex;align-items:center;justify-content:center;width:1.5em;height:1.5em;font-size:1.5em;line-height:1}.sun{padding-top:.05em;scale:.8}.moon{scale:.35}.marquee-word[data-v-317d61fe]{position:absolute;left:0;width:100vw;overflow:hidden;z-index:0;pointer-events:none;-webkit-user-select:none;user-select:none}.marquee-word__inner[data-v-317d61fe]{display:flex;width:max-content;min-width:200vw;animation-name:marquee-word-scroll-317d61fe;animation-timing-function:linear;animation-iteration-count:infinite;animation-duration:var(--34756a8b);animation-direction:var(--eda42f92)}.marquee-word__inner span[data-v-317d61fe]{font-family:Impact;font-size:14vw;font-weight:900;opacity:.04;color:var(--scroll-bg-word);white-space:nowrap;letter-spacing:.05em;text-shadow:0 2px 16px rgba(59,130,246,.15);padding-right:3vw;display:inline-block;text-transform:uppercase}[data-v-317d61fe]:root{--scroll-bg-word: var(--color-blue)}html[data-theme=light][data-v-317d61fe]{--scroll-bg-word: var(--color-blue-hover)}@keyframes marquee-word-scroll-317d61fe{0%{transform:translate(0)}to{transform:translate(-50%)}}@media (max-width: 600px){.marquee-word[data-v-317d61fe]{width:100vw;left:0}.marquee-word__inner[data-v-317d61fe]{min-width:200vw}}.home[data-v-71143f80]{position:relative;overflow:hidden;width:100%}.hero[data-v-71143f80]{display:flex;justify-content:center;text-align:left;background:none;position:relative;z-index:1;width:100%}.hero-inner[data-v-71143f80]{display:flex;align-items:center;justify-content:center;width:100%;max-width:1200px;padding:0 1rem}.hero-content[data-v-71143f80]{max-width:480px;padding:0;position:relative;z-index:2;display:flex;flex-direction:column;align-items:flex-start;width:100%}.hero-title[data-v-71143f80]{font-size:clamp(2.5rem,5vw,4rem);font-weight:700;margin-bottom:.5rem;line-height:1.2}.hero-subtitle[data-v-71143f80]{display:flex;font-size:1.3rem;font-weight:200}.hero-subtitle p[data-v-71143f80]{padding:1rem .2rem;transform:none;transition:all 1.6s}.hero-cta[data-v-71143f80]{display:flex;gap:1rem;margin-top:1.5rem;opacity:0}.cta-button[data-v-71143f80]{padding:1rem 2rem;text-decoration:none;border-radius:8px;font-weight:600;font-size:1.1rem;transition:all .3s ease;position:relative;overflow:hidden;border:none;cursor:pointer;box-shadow:0 2px 12px #3b82f614}.cta-button.secondary[data-v-71143f80]{display:flex;position:relative;overflow:hidden;justify-content:right;align-items:center;text-decoration:none;margin:.75rem;padding:1.25rem 1.75rem;color:var(--color-blue);border-radius:.5rem;border:.15rem solid var(--color-blue);font-weight:800;font-size:.95rem;background-color:transparent;transition:all .3s ease-out}.cta-button.secondary[data-v-71143f80]:hover{scale:1.1;background-color:var(--color-blue);border-radius:.25rem;color:var(--color-white)}.hero-gif[data-v-71143f80]{flex:0 1 380px;display:flex;align-items:center;justify-content:center;min-width:220px;max-width:420px;z-index:2;margin-left:0}.hero-gif img[data-v-71143f80]{width:100%;background:transparent}@media (max-width: 1100px){.hero-inner[data-v-71143f80]{gap:2vw;max-width:900px}.hero-content[data-v-71143f80]{max-width:400px}.hero-gif img[data-v-71143f80]{max-width:300px}}@media (max-width: 900px){.hero-inner[data-v-71143f80]{flex-direction:column;align-items:center;justify-content:center;max-width:100%;padding:0 1rem}.hero-content[data-v-71143f80]{align-items:center;max-width:100%;text-align:center;padding:0}.hero-gif[data-v-71143f80]{display:none}}@media (max-width: 600px){.home[data-v-71143f80]{margin-bottom:55%;padding-top:5rem}.hero-inner[data-v-71143f80]{padding:0 .5rem}.hero-content[data-v-71143f80]{padding:0}.scroll-indicator[data-v-71143f80]{bottom:2.5rem}.fade-in-up[data-v-71143f80]{animation:none;opacity:1;transform:none}.marquee-word[data-v-71143f80]{transform:translateY(-85px)}}.project-card[data-v-a743ecf2]{border-radius:12px;background-color:var(--color-light-grey);overflow:hidden;cursor:pointer;transition:all .4s ease;border:1px solid transparent;position:relative}.project-card[data-v-a743ecf2]:hover{transform:translateY(-8px);border-color:var(--color-blue);box-shadow:0 20px 40px #0000004d}.card-image[data-v-a743ecf2]{background-color:var(--color-light-grey);position:relative;height:200px;overflow:hidden;display:flex;align-items:center;justify-content:center}.card-image img[data-v-a743ecf2]{width:100%;height:100%;object-fit:cover;object-position:center;display:block;transition:transform .4s ease}.project-card:hover .card-image img[data-v-a743ecf2]{transform:scale(1.1)}.card-overlay[data-v-a743ecf2]{position:absolute;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s ease}.project-card:hover .card-overlay[data-v-a743ecf2]{opacity:1}.overlay-content[data-v-a743ecf2]{text-align:center}.view-project[data-v-a743ecf2]{color:var(--color-white);font-weight:600;font-size:1.1rem;padding:.5rem 1rem;border:2px solid var(--color-blue);border-radius:6px;transition:all .3s ease}.project-card:hover .view-project[data-v-a743ecf2]{background-color:var(--color-blue);transform:scale(1.05)}.card-content[data-v-a743ecf2]{padding:1.5rem}.card-header[data-v-a743ecf2]{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;gap:1rem}.card-title[data-v-a743ecf2]{font-size:1.25rem;font-weight:600;color:var(--color-white);margin:0;line-height:1.3}.card-date[data-v-a743ecf2]{color:var(--color-blue);font-size:.9rem;font-weight:500;white-space:nowrap}.card-description[data-v-a743ecf2]{color:var(--color-dark-grey);line-height:1.6;margin-bottom:1rem;font-size:.95rem}.card-tech[data-v-a743ecf2]{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.tech-tag[data-v-a743ecf2]{background-color:gray;color:#fff;padding:.25rem .75rem;border-radius:20px;font-size:.8rem;font-weight:500;transition:all .3s ease}.project-card:hover .tech-tag[data-v-a743ecf2]{background-color:var(--color-blue);transform:translateY(-1px)}.tech-more[data-v-a743ecf2]{color:var(--color-blue);font-size:.8rem;font-weight:600}.no-image-placeholder[data-v-a743ecf2]{position:absolute;top:0;left:0;right:0;bottom:0;background-color:var(--color-light-grey);display:flex;align-items:center;justify-content:center;color:var(--color-dark-grey);font-size:1.2rem;font-weight:500;text-align:center;padding:1rem}@media (max-width: 768px){.project-card[data-v-a743ecf2]{margin-bottom:1rem}.card-header[data-v-a743ecf2]{flex-direction:column;align-items:flex-start;gap:.5rem}.card-date[data-v-a743ecf2]{align-self:flex-end}.card-content[data-v-a743ecf2]{padding:1rem}.card-title[data-v-a743ecf2]{font-size:1.1rem}.card-description[data-v-a743ecf2]{font-size:.9rem}.project-card[data-v-a743ecf2]:hover{transform:none;border-color:transparent;box-shadow:none}.project-card:hover .card-image img[data-v-a743ecf2]{transform:none}.project-card:hover .card-overlay[data-v-a743ecf2]{opacity:0}.project-card:hover .view-project[data-v-a743ecf2]{background-color:transparent;transform:none}.project-card:hover .tech-tag[data-v-a743ecf2]{background-color:gray;transform:none}}@media (max-width: 480px){.card-image[data-v-a743ecf2]{height:150px}.card-content[data-v-a743ecf2]{padding:.75rem}.card-title[data-v-a743ecf2]{font-size:1rem}.card-description[data-v-a743ecf2]{font-size:.85rem}.tech-tag[data-v-a743ecf2]{font-size:.7rem;padding:.2rem .5rem}}.featured-projects[data-v-51c7f22f]{text-align:center}.section-title[data-v-51c7f22f]{transition:all .3s ease;font-size:2.5rem;font-weight:700;text-align:center;margin-bottom:3rem;color:var(--color-white);position:relative;background-color:transparent;border-color:transparent}.section-title[data-v-51c7f22f]:after{content:"";position:absolute;bottom:-10px;left:50%;transform:translate(-50%);width:60px;height:3px;background-color:var(--color-blue)}.projects-grid[data-v-51c7f22f]{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;margin-top:2rem}@media (max-width: 768px){.section-title[data-v-51c7f22f]{font-size:2rem}.projects-grid[data-v-51c7f22f]{grid-template-columns:1fr;gap:1.5rem}.fade-in-up[data-v-51c7f22f]{animation:none;opacity:1;transform:none}}.projects-view{min-height:100vh;padding:2rem 0;position:relative;overflow:hidden;width:100%;z-index:1}.container{max-width:1200px;margin:0 auto;padding:0 2rem;position:relative;z-index:2}.projects-header{text-align:center;margin-bottom:3rem}.page-title{font-size:3.5rem;font-weight:800;color:var(--color-white);margin-bottom:.5rem}.page-subtitle{font-size:1.2rem;color:var(--color-gray);margin-bottom:2rem}.section-title{transition:all .3s ease;font-size:2.5rem;font-weight:700;text-align:center;margin-bottom:3rem;color:var(--color-white);position:relative;background-color:transparent;border-color:transparent}.section-title:after{content:"";position:absolute;bottom:-10px;left:50%;transform:translate(-50%);width:60px;height:3px;background-color:var(--color-blue)}.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;margin-top:2rem}@media (max-width: 768px){.projects-view{padding:1rem 0}.container{padding:0 1rem}.page-title{font-size:2.5rem}.page-subtitle{font-size:1rem}.section-title{font-size:1.5rem}.projects-grid{grid-template-columns:1fr;gap:1.5rem;margin-top:1rem}.other-projects-section{margin-top:2rem}}@media (max-width: 480px){.projects-view{margin-top:30%;margin-bottom:50%;padding:.5rem 0}.container{padding:0 .5rem}.page-title{font-size:2rem}.section-title{font-size:1.25rem}.projects-grid{gap:1rem}.marquee-word{transform:translateY(50px)}}.about[data-v-18a354a4]{margin-top:100px;margin-bottom:100px;min-height:100vh;position:relative;overflow:hidden;width:100%}.container[data-v-18a354a4]{max-width:1200px;margin:0 auto;padding:0 1rem}.about-header[data-v-18a354a4]{text-align:center;margin-bottom:4rem}.page-title[data-v-18a354a4]{font-size:3rem;font-weight:700;color:var(--color-white);margin-bottom:1rem}.page-subtitle[data-v-18a354a4]{font-size:1.2rem;color:var(--color-white)}.about-content[data-v-18a354a4]{display:grid;grid-template-columns:2fr 1fr;gap:2rem;margin-bottom:4rem;align-items:start}.text-section[data-v-18a354a4]{padding:2rem;background-color:var(--color-light-grey);border-radius:1rem}.text-section h2[data-v-18a354a4]{color:var(--color-white);font-size:1.8rem;font-weight:600;margin-bottom:1.5rem}.text-section p[data-v-18a354a4]{color:var(--color-dark-grey);line-height:1.7;margin-bottom:1rem;font-size:1.05rem}.services-grid[data-v-18a354a4]{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-top:2rem}.service-item[data-v-18a354a4]{background-color:var(--color-dark-grey);padding:1.5rem;border-radius:8px;border:2px solid transparent;transition:all .3s ease}.service-item[data-v-18a354a4]:hover{border-color:var(--color-blue);transform:translateY(-5px)}.service-item h3[data-v-18a354a4]{color:var(--color-white);font-size:1.2rem}.about-image[data-v-18a354a4]{display:flex;align-items:center;justify-content:center}.image-container[data-v-18a354a4]{width:20rem;margin-top:0%;padding-top:0%;margin-bottom:3%;transform:translateY(20%);border-radius:1.5rem;overflow:hidden}.image-container img[data-v-18a354a4]{width:100%;display:block;border-radius:1.5rem}.resume-section[data-v-18a354a4]{margin-top:8rem;padding:2rem;border-radius:1rem;background-color:var(--color-light-grey)}.resume-section h2[data-v-18a354a4]{color:var(--color-blue);font-size:1.5rem;font-weight:700;margin-bottom:2rem}.resume-content[data-v-18a354a4]{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:3rem;margin-bottom:2rem;color:var(--color-white)}.resume-column[data-v-18a354a4]{flex:2}.timeline[data-v-18a354a4]{border-left:3px solid var(--color-blue);padding-left:1.5rem}.timeline-item[data-v-18a354a4]{margin-bottom:2rem}.timeline-date[data-v-18a354a4]{color:var(--color-blue);font-weight:600;margin-bottom:.5rem}.timeline-content h4[data-v-18a354a4]{color:var(--color-white);font-size:1.1rem;font-weight:600;margin-bottom:.3rem}.timeline-content p[data-v-18a354a4]{color:var(--color-dark-grey);font-size:1rem}.resume-download[data-v-18a354a4]{margin-top:2rem}@media (max-width: 1100px){.about-content[data-v-18a354a4]{grid-template-columns:1fr;gap:2rem}.about-image[data-v-18a354a4]{margin-top:2rem}}@media (max-width: 600px){.about-header[data-v-18a354a4]{margin-bottom:2rem;padding-top:4rem}.about-content[data-v-18a354a4]{gap:1.5rem}.image-container[data-v-18a354a4]{max-width:90vw}.resume-section[data-v-18a354a4]{margin-top:2rem}.fade-in-up[data-v-18a354a4]{animation:none;opacity:1;transform:none}.stagger-children[data-v-18a354a4]>*{opacity:1;transform:none;transition:none}.marquee-word[data-v-18a354a4]{transform:translateY(-350px)}}.skills[data-v-ed9775c0]{padding:2rem 0;position:relative;overflow:hidden;width:100%;height:100%}.container[data-v-ed9775c0]{max-width:1200px;margin:0 auto;padding:0 2rem}.skills-header[data-v-ed9775c0]{text-align:center;margin-bottom:4rem}.page-title[data-v-ed9775c0]{font-size:3rem;font-weight:700;color:var(--color-white);margin-bottom:1rem}.page-subtitle[data-v-ed9775c0]{font-size:1.2rem;color:var(--color-white)}.skill-category[data-v-ed9775c0]{margin-bottom:4rem}.category-title[data-v-ed9775c0]{color:var(--color-blue);font-size:2rem;font-weight:600;margin-bottom:2rem;position:relative}.category-title[data-v-ed9775c0]:after{content:"";position:absolute;bottom:-5px;left:0;width:50px;height:3px;background-color:var(--color-blue)}.skills-grid[data-v-ed9775c0]{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}.skill-item[data-v-ed9775c0]{background-color:var(--color-light-grey);padding:1.5rem;border-radius:12px;border:2px solid transparent;transition:all .3s ease;display:flex;align-items:center;gap:1rem;animation:fadeInUp .6s ease-out forwards;opacity:0}.skill-item[data-v-ed9775c0]:hover{border-color:var(--color-blue);transform:translateY(-5px);box-shadow:0 10px 25px #0003}.skill-icon[data-v-ed9775c0]{width:50px;height:50px;display:flex;align-items:center;justify-content:center;background-color:transparent;border-radius:8px;flex-shrink:0}.skill-icon img[data-v-ed9775c0]{width:36px;height:36px;object-fit:contain;display:block}.skill-info[data-v-ed9775c0]{flex:1}.skill-name[data-v-ed9775c0]{color:var(--color-white);font-size:1.1rem;font-weight:600;margin-bottom:.5rem}@media (max-width: 1100px){.skills-content[data-v-ed9775c0]{gap:2rem}}@media (max-width: 600px){.skills[data-v-ed9775c0]{margin-top:30%;padding-top:4rem}.skills-header[data-v-ed9775c0]{margin-bottom:2rem}.skills-content[data-v-ed9775c0]{gap:1.5rem}.fade-in-up[data-v-ed9775c0]{animation:none;opacity:1;transform:none}.stagger-children[data-v-ed9775c0]>*{opacity:1;transform:none;transition:none}.marquee-word[data-v-ed9775c0]{transform:translateY(-390px)}}.contact{margin-bottom:100px;min-height:50vh;padding:2rem 0}.container{max-width:1200px;margin:0 auto;padding:0 2rem}.contact-header{text-align:center;margin-bottom:4rem}.page-title{font-size:3rem;font-weight:700;color:var(--color-white);margin-bottom:1rem}.page-subtitle{font-size:1.2rem;color:var(--color-dark-grey)}.contact-content{display:grid;grid-auto-flow:row;padding:1rem}.contact-info{display:grid;grid-template-columns:1fr 1fr 1fr;background-color:var(--color-light-grey);border-radius:1rem}.info-item{display:flex;text-align:center;justify-content:center;margin:1rem;padding:1rem;border-radius:8px;border:1px solid transparent;color:var(--color-white)}.info-details h3{font-size:1.7rem;border-bottom:1px solid var(--color-dark-grey);font-weight:350;margin-bottom:.5rem}.social-links{display:flex;justify-content:center;margin:1rem;padding:1rem;border-top:1px solid var(--color-dark-grey)}.social-links h3{color:var(--color-white);font-size:1.2rem;font-weight:600;margin-bottom:1rem}.social-grid{display:flex;flex-direction:row;gap:1rem}.social-link{display:flex;align-items:center;gap:.75rem;padding:.75rem;color:var(--color-dark-grey);text-decoration:none;border-radius:1rem;transition:all .3s ease;border:1px solid transparent}.social-link:hover{color:var(--color-blue);border-color:var(--color-blue-hover)}.social-icon{font-size:1.2rem}@media (max-width: 1200px){.container{padding:0 1rem}.page-title{font-size:2.5rem}.page-subtitle{font-size:1rem}.contact-info{display:flex;flex-wrap:wrap;flex-flow:column}.contact-info{order:2}.contact-form{order:1}.social-grid{flex-direction:row;flex-wrap:wrap}.fade-in-up{animation:none;opacity:1;transform:none}.stagger-children>*{opacity:1;transform:none;transition:none}}.modal-overlay[data-v-7cf3f194]{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:2000;padding:2rem;animation:fadeIn-7cf3f194 .3s ease-out}.modal-content[data-v-7cf3f194]{background-color:var(--color-light-grey);border-radius:12px;max-width:1600px;width:100%;height:100%;overflow-y:auto;position:relative;animation:slideInUp-7cf3f194 .3s ease-out}.modal-close[data-v-7cf3f194]{position:absolute;top:1rem;right:1rem;background:none;border:none;color:var(--color-white);font-size:2rem;cursor:pointer;z-index:10;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.modal-close[data-v-7cf3f194]:hover{background-color:var(--color-grey);transform:scale(1.1)}.project-detail[data-v-7cf3f194]{display:grid;grid-template-columns:1fr 1fr;gap:2rem;padding:2rem}.project-image[data-v-7cf3f194]{overflow:hidden;position:relative;display:flex;align-content:space-between;flex-direction:column}.project-image img[data-v-7cf3f194]{display:flex;width:80%;height:auto;margin:2rem}.project-info[data-v-7cf3f194]{display:flex;flex-direction:column;gap:1.5rem}.project-title[data-v-7cf3f194]{font-size:2rem;font-weight:700;color:var(--color-white);margin:0}.project-date[data-v-7cf3f194]{color:var(--color-dark-grey);font-size:.9rem;margin:0}.project-description[data-v-7cf3f194]{color:var(--color-dark-grey);line-height:1.6;margin:0}.project-features h3[data-v-7cf3f194]{color:var(--color-white);font-size:1.1rem;margin-bottom:.5rem}.features-list[data-v-7cf3f194]{list-style:none;padding:0;margin:0}.features-list li[data-v-7cf3f194]{color:var(--color-dark-grey);position:relative;padding:.25rem 0 .25rem 1.5rem}.features-list li[data-v-7cf3f194]:before{content:"▶";position:absolute;left:0;color:var(--color-blue);font-size:.8rem}.project-technologies h3[data-v-7cf3f194]{color:var(--color-white);font-size:1.1rem;margin-bottom:.5rem}.tech-tags[data-v-7cf3f194]{display:flex;flex-wrap:wrap;gap:.5rem}.tech-tag[data-v-7cf3f194]{background-color:var(--color-blue);color:var(--color-white);padding:.25rem .75rem;border-radius:20px;font-size:.8rem;font-weight:500}.project-links[data-v-7cf3f194]{display:flex;gap:1rem}.project-link[data-v-7cf3f194]{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;text-decoration:none;border-radius:8px;font-weight:600;transition:all .3s ease}.project-link.github[data-v-7cf3f194]{background-color:var(--color-light-grey);color:var(--color-white);border:2px solid var(--color-grey)}.project-link.github[data-v-7cf3f194]:hover{border-color:var(--color-blue);color:var(--color-blue);transform:translateY(-2px)}.project-link.demo[data-v-7cf3f194]{background-color:var(--color-blue);color:var(--color-white)}.project-link.demo[data-v-7cf3f194]:hover{background-color:var(--color-blue-hover);transform:translateY(-2px)}.extra-images[data-v-7cf3f194]{display:flex;flex-direction:row;justify-content:space-evenly;align-items:center;background-color:var(--color-light-grey);border-radius:.5rem;margin:1.5rem;padding:2rem}.extra-images img[data-v-7cf3f194]{transition:all .3s ease-out;width:25vw;height:auto;border-radius:.5rem;border:.2rem solid transparent}.extra-images img[data-v-7cf3f194]:hover{scale:1.1;border-radius:.2rem;border-color:var(--color-blue)}@keyframes fadeIn-7cf3f194{0%{opacity:0}to{opacity:1}}@keyframes slideInUp-7cf3f194{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.modal-overlay[data-v-7cf3f194]{width:auto;padding:1rem}.project-image[data-v-7cf3f194]{display:none}.project-detail[data-v-7cf3f194]{grid-template-columns:1fr;gap:1.5rem;padding:1.5rem}.project-title[data-v-7cf3f194]{font-size:1.5rem}.project-links[data-v-7cf3f194]{flex-direction:column}.extra-images[data-v-7cf3f194]{flex-direction:column;align-content:space-evenly;margin:1rem;padding:1rem}.extra-images img[data-v-7cf3f194]{width:70vw}}.single-page section{min-height:65vh;width:100%}@media (max-width: 1800px){.single-page section{min-height:40vh}}@media (max-width: 1200px){.single-page section{min-height:30vh}}@media (max-width: 700px){.single-page section{min-height:5vh;width:100%;max-width:100%}}.single-page section>*{transition:all .3s ease}.main-content[data-v-c8b1014d]{min-height:100vh;padding-top:80px;overflow:visible}@media (max-width: 768px){.main-content[data-v-c8b1014d]{padding-top:70px}}
