@font-face{font-family:Inter;src:url(/assets/Inter-VariableFont_opsz_wght-c8O0ljhh.ttf);font-weight:100 900;font-style:normal;font-display:swap}@font-face{font-family:Inter;src:url(/assets/Inter-Italic-VariableFont_opsz_wght-B-9PvMw6.ttf);font-weight:100 900;font-style:italic;font-display:swap}*{margin:0;padding:0;box-sizing:border-box;scrollbar-width:none;will-change:auto!important}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background-color:#0b1220;color:#e5e7eb;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html{scroll-behavior:smooth}.scroll-indicator,.progress-ring-circle{will-change:transform,opacity}.app{position:relative;width:100%;overflow-x:hidden}section{position:relative;width:100%}.delicate-dots-background{pointer-events:auto;position:fixed;width:100%;height:100dvh;top:0;left:0}.content-wrapper{position:relative;z-index:1;pointer-events:none}.language-switcher{z-index:9999;display:flex;justify-content:center;align-items:center;gap:.5rem;background-color:#0b1220;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:.5rem;border-radius:1rem;border:2px solid #1E3A8A}.language-switcher-button{width:50px;height:34px;padding:.2rem;background-color:transparent;border:2px solid transparent;border-radius:1rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;overflow:hidden}.language-switcher-button:hover{border-color:#38bdf8;transform:scale(1.1)}.language-switcher-button.active{border-color:#38bdf8}.language-flag{width:100%;height:100%;display:flex;align-items:center;justify-content:center;border-radius:1rem;overflow:hidden}.language-flag svg{width:110%;height:110%}@media(max-width:768px){.language-switcher-button{width:44px;height:30px}}@media(max-width:480px){.language-switcher-button{width:38px;height:26px}}.navbar{width:100%;position:fixed;padding:1.5rem;z-index:1000;pointer-events:all}.container{width:100%;display:flex;flex-direction:row-reverse;justify-content:space-between;align-items:center}.menu-toggle{background:none;border:none;cursor:pointer;padding:.5rem;border-radius:.5rem;transition:background-color .3s ease;position:relative;z-index:1001}.menu-toggle:hover{background-color:#ffffff1a}.menu-icon{position:relative;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.menu-burger,.menu-close{position:absolute;transition:all .3s cubic-bezier(.4,0,.2,1)}.menu-burger.visible{opacity:1;transform:rotate(0) scale(1)}.menu-burger.hidden{opacity:0;transform:rotate(-90deg) scale(.8)}.menu-close.visible{opacity:1;transform:rotate(0) scale(1)}.menu-close.hidden{opacity:0;transform:rotate(90deg) scale(.8)}.menu-overlay{position:fixed;top:0;left:0;width:100%;height:100vh;background-color:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease;z-index:998}.menu-overlay.open{opacity:1;visibility:visible}.menu-content{position:fixed;top:0;right:0;width:300px;height:100vh;background:#0f172af2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-left:1px solid rgba(56,189,248,.3);transform:translate(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);z-index:999;padding:2rem 0}.menu-content.open{transform:translate(0)}.menu-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem;margin-top:4rem}.menu-item{width:100%}.menu-link{width:100%;background:none;border:none;color:#e2e8f0;padding:1rem 2rem;text-align:left;font-size:1.1rem;font-weight:500;cursor:pointer;transition:all .3s ease;border-left:3px solid transparent}.menu-link:hover{background-color:#38bdf81a;border-left-color:#38bdf8;color:#38bdf8}@media(max-width:768px){.menu-content{width:280px}.menu-link{padding:.8rem 1.5rem;font-size:1rem}}@media(max-width:480px){.menu-content{width:100%}}.hero-section{min-height:100vh;height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;position:relative;overflow:hidden}.hero-content-container{width:100%;display:flex;align-items:center;justify-content:center}.hero-container{padding:2rem;max-width:1200px;width:100%;position:relative}.hero-content{padding:1rem;display:flex;align-items:center;justify-content:space-between;gap:3rem}.hero-text{flex:1}.hero-title{font-size:clamp(2rem,5vw,3.5rem);font-weight:700;margin-bottom:.5rem;-webkit-text-stroke:2px #E5E7EB;color:transparent}.hero-subtitle{font-size:clamp(2rem,5vw,3.5rem);font-weight:900;margin-bottom:1.5rem}.hero-description{font-size:1.2rem;color:#9ca3af;display:inline-block}.hero-image-wrapper{flex-shrink:0;position:relative;cursor:pointer;width:430px;height:430px;display:flex;align-items:center;justify-content:center}.hero-image{width:340px;height:340px;border-radius:50%;object-fit:cover;border:2px solid #38BDF8;pointer-events:all;cursor:pointer}.circle-text{position:absolute;width:100%;height:100%;top:0;left:0;pointer-events:none}@media(max-width:1024px){.hero-image-wrapper{width:330px;height:330px}.hero-image{width:250px;height:250px}.circle-text text{font-size:10px;letter-spacing:3px}}@media(max-width:768px){.hero-section,.hero-container{padding:1rem}.hero-content{flex-direction:column;text-align:center;gap:2rem}.hero-image-wrapper{width:260px;height:260px}.hero-image{width:200px;height:200px}.circle-text text{font-size:10px;letter-spacing:2px}.hero-title,.hero-subtitle{font-size:clamp(1.5rem,8vw,2.5rem)}.hero-description{font-size:1rem}}@media(max-width:480px){.hero-section{padding:.5rem}.hero-image-wrapper{width:200px;height:200px}.hero-image{width:150px;height:150px}.circle-text text{font-size:10px;letter-spacing:1px}.hero-title,.hero-subtitle{font-size:clamp(1.2rem,7vw,2rem)}}.scroll-indicator{position:fixed;bottom:2rem;left:50%;transform:translate(-50%);z-index:1000}.progress-ring{position:absolute;top:0;left:0;transform:rotate(-90deg);opacity:0}.progress-ring-background{fill:#0b1220;stroke:#1e3a8a4d;stroke-width:4}.progress-ring-circle{fill:none;stroke:#38bdf8;stroke-width:4;stroke-linecap:round;stroke-dasharray:219.91;stroke-dashoffset:219.91;transition:stroke-dashoffset .3s ease}.scroll-content{position:relative;width:80px;height:80px;display:flex;align-items:center;justify-content:center}.scroll-arrow{position:absolute;background-color:#1e3a8a;width:80px;height:80px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#e5e7eb;cursor:pointer}.scroll-percentage{position:absolute;font-size:1.2rem;font-weight:700;color:#e5e7eb;opacity:0;transform:scale(0)}.about-section{min-height:100vh;height:100vh;pointer-events:none;display:flex;align-items:center;justify-content:center;padding:2rem;position:relative;overflow:hidden}.about-container{width:70%;max-width:900px;padding:2rem;border:1px solid rgba(56,189,248,.2);border-radius:1rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0b122066;box-shadow:0 8px 32px #1e3a8a5e;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:1rem;pointer-events:none;position:relative;z-index:1}.about-title{text-align:center;margin-bottom:1rem;font-size:clamp(2rem,5vw,2.5rem);font-weight:900}.about-text{text-align:justify;align-self:start;font-size:clamp(.9rem,2vw,1.1rem);line-height:1.6}.about-button{width:25%;min-width:150px;padding:1rem;margin-top:1rem;pointer-events:auto;background-color:transparent;border:1px solid #1E3A8A;border-radius:1rem;color:#e5e7eb;font-family:Inter,sans-serif;font-size:clamp(.9rem,2vw,1rem);font-weight:600;transition:all .2s ease-in-out;cursor:pointer}.about-button:hover{box-shadow:0 0 20px #1e3a8a;border-color:#38bdf8}@media(max-width:1024px){.about-container{width:80%;padding:2rem 1.5rem}.about-button{width:35%}}@media(max-width:768px){.about-section{padding:1.5rem}.about-container{width:90%;padding:1.5rem;gap:.8rem}.about-title{margin-bottom:.8rem}.about-text{text-align:left}.about-button{width:50%;min-width:120px;padding:.8rem}}@media(max-width:480px){.about-section{padding:1rem}.about-container{width:95%;padding:1.2rem;gap:.6rem}.about-title{margin-bottom:.5rem}.about-text{line-height:1.5}.about-button{width:70%;padding:.8rem;margin-top:.5rem}}@media(max-width:360px){.about-section{padding:.8rem}.about-container{width:98%;padding:1rem}.about-button{width:80%;font-size:.85rem}}.stack-section{min-height:100vh;height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;position:relative;overflow:hidden}.stack-container{width:80%;max-width:1000px;padding:2.5rem;border:1px solid rgba(56,189,248,.2);border-radius:1rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0b122066;box-shadow:0 8px 32px #1e3a8a5e;pointer-events:none;position:relative;z-index:1}.stack-title{font-size:clamp(2rem,5vw,2.5rem);font-weight:900;text-align:center}.stack-iconTitle{display:flex;gap:1rem;justify-content:start;align-items:center;margin-bottom:.7rem}.stack-description{font-size:clamp(.9rem,2vw,1.1rem);text-align:center;color:#9ca3af;margin-bottom:2.5rem}.stack-categories{display:flex;flex-direction:column;gap:2rem}.stack-category{border-left:3px solid #38BDF8;padding-left:1.5rem}.category-title{font-size:clamp(1rem,2vw,1.3rem);font-weight:600;color:#38bdf8}.tech-grid{display:flex;flex-wrap:wrap;gap:1rem}.tech-item{display:flex;align-items:center;gap:.5rem;padding:.3rem .7rem;background-color:#1e3a8a33;border:1px solid rgba(56,189,248,.3);border-radius:1rem;font-size:clamp(.9rem,2vw,1rem);transition:all .2s ease}.tech-icon svg{width:20px;height:20px;flex-shrink:0;display:flex;justify-content:center;align-items:center}.tech-name{font-weight:500}.infinite-line{width:100vw;margin-bottom:2rem;border-top:1px solid #38BDF8;border-bottom:1px solid #38BDF8;padding:2px 0;display:flex;overflow-x:auto;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.infinite-line::-webkit-scrollbar{display:none}.infinite-tech{display:flex;align-items:center;justify-content:center;animation:linear-spin 10s infinite linear}.infinite-tech-item{margin-right:2rem}@keyframes linear-spin{0%{translate:0}to{translate:-100%}}@media(max-width:1024px){.stack-container{width:85%;padding:2rem}.stack-categories{gap:1.5rem}}@media(max-width:768px){.stack-section{padding:1.5rem}.stack-container{width:90%;padding:1.5rem}.stack-description{margin-bottom:2rem}.stack-categories{gap:1.5rem}.stack-category{padding-left:1rem;border-left-width:2px}.tech-grid{gap:.8rem}.tech-item{padding:.4rem .8rem}}@media(max-width:480px){.stack-section{padding:1rem}.stack-container{width:95%;padding:1.2rem}.stack-categories{gap:1.2rem}.tech-grid{gap:.6rem}.tech-item{padding:.3rem .6rem;font-size:.85rem}.tech-icon{font-size:1.2rem}}@media(max-width:360px){.stack-container{width:98%;padding:1rem}.tech-item{padding:.3rem .5rem;font-size:.8rem}}.projects-section{min-height:100vh;height:100vh;display:flex;justify-content:center;align-items:center;padding:2rem;position:relative;overflow:hidden;pointer-events:all}.projects-container{width:100%;max-width:1200px;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center}.projects-title{text-align:center;font-weight:900;font-size:clamp(2rem,5vw,3rem);margin-bottom:3rem;background:linear-gradient(to right,#38bdf8,#818cf8);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.projects-cards-wrapper{position:relative;width:100%;max-width:900px;height:600px;perspective:1000px}.project-card{position:absolute;top:0;left:0;width:100%;height:100%;cursor:pointer}.card-inner{position:relative;width:100%;height:100%;transition:transform .8s cubic-bezier(.4,0,.2,1);transform-style:preserve-3d}.card-inner.flipped{transform:rotateY(180deg)}@media(hover:hover)and (pointer:fine){.project-card:hover .card-inner:not(.flipped){transform:rotateY(180deg)}}.card-front,.card-back{position:absolute;width:100%;height:100%;backface-visibility:hidden;border-radius:1rem;overflow:hidden;background:#0f172ab3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(56,189,248,.3);box-shadow:0 20px 60px #0006}.card-front{display:flex;flex-direction:column}.card-back{transform:rotateY(180deg);padding:2rem;overflow-y:auto}.project-image{width:100%;height:60%;overflow:hidden;position:relative}.project-image img{width:100%;height:100%;object-fit:cover;object-position:top;transition:transform .3s ease}@media(hover:hover)and (pointer:fine){.project-card:hover .project-image img{transform:scale(1.05)}}.project-image:after{content:"";position:absolute;bottom:0;left:0;right:0;height:100px;background:linear-gradient(to top,rgba(15,23,42,1),transparent)}.project-front-content{padding:2rem;flex:1;display:flex;flex-direction:column;gap:1rem}.project-title{font-size:clamp(1.5rem,3vw,2rem);font-weight:700;color:#38bdf8}.project-short-desc{color:#94a3b8;font-size:clamp(.9rem,2vw,1rem);line-height:1.6}.project-tech-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:auto}.tech-tag{padding:.3rem .8rem;background:#38bdf81a;border:1px solid rgba(56,189,248,.3);border-radius:1rem;font-size:.85rem;color:#38bdf8}.hover-hint{text-align:center;color:#64748b;font-size:.85rem;font-style:italic;margin-top:.5rem}.mobile-hint{display:none}@media(max-width:768px){.desktop-hint{display:none}.mobile-hint{display:block}}.project-back-content{display:flex;flex-direction:column;gap:1.5rem;height:100%}.project-full-desc{color:#cbd5e1;line-height:1.6}.project-features,.project-tech-stack{display:flex;flex-direction:column;gap:.8rem}.project-features h4,.project-tech-stack h4{color:#38bdf8;font-size:1.1rem;font-weight:600}.project-features ul{list-style:none;padding:0;display:flex;flex-direction:column;gap:.5rem}.project-features li{color:#94a3b8;padding-left:1.5rem;position:relative}.project-features li:before{content:"▹";position:absolute;left:0;color:#38bdf8;font-size:1.2rem}.tech-tags-back{display:flex;flex-wrap:wrap;gap:.5rem}.project-links{display:flex;gap:1rem;margin-top:auto}.project-link{flex:1;padding:.8rem 1.5rem;text-align:center;text-decoration:none;border-radius:.5rem;font-weight:600;transition:all .3s ease;background:transparent;border:2px solid #38BDF8;color:#38bdf8;display:flex;flex-direction:row-reverse;align-items:center;justify-content:center;gap:.5rem}.project-link.primary{background:#38bdf8;color:#0f172a}.project-link:hover{transform:translateY(-2px);box-shadow:0 5px 20px #38bdf84d}.project-link.primary:hover{background:#0ea5e9;border-color:#0ea5e9}.card-back::-webkit-scrollbar{width:6px}.card-back::-webkit-scrollbar-track{background:#1e293b80;border-radius:10px}.card-back::-webkit-scrollbar-thumb{background:#38bdf880;border-radius:10px}.card-back::-webkit-scrollbar-thumb:hover{background:#38bdf8b3}@media(max-width:768px){.projects-cards-wrapper{height:500px}.card-back{padding:1.5rem}.project-links{flex-direction:column;margin-top:1.5rem}}.contact-section{min-height:100vh;display:flex;justify-content:center;align-items:center;padding:0;position:relative;overflow:hidden}.contact-container{width:70%;max-width:1200px;padding:2rem;border:2px solid #1E3A8A;border-radius:1rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0b122099;box-shadow:0 8px 32px #1e3a8a5e;pointer-events:auto}.contact-title{font-size:clamp(2rem,5vw,2.5rem);font-weight:900;text-align:center;margin-bottom:1rem}.contact-box{display:flex;justify-content:space-between;align-items:stretch;gap:3rem}.contact-form-wrapper{flex:1;display:flex;flex-direction:column}.form-subtitle{font-size:1.5rem;font-weight:700;color:#38bdf8;margin-bottom:1rem}.contact-form{display:flex;flex-direction:column;gap:.8rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-label{display:flex;align-items:center;gap:.5rem;font-size:.9rem;font-weight:600;color:#e5e7eb}.form-input,.form-textarea{width:100%;padding:.75rem;background-color:#1e3a8a33;border:2px solid rgba(56,189,248,.3);border-radius:.5rem;color:#e5e7eb;font-family:Inter,sans-serif;font-size:1rem;transition:all .2s ease}.form-input:focus,.form-textarea:focus{outline:none;border-color:#38bdf8;background-color:#1e3a8a4d}.form-input::placeholder,.form-textarea::placeholder{color:#9ca3af}.form-textarea{resize:none;min-height:100px}.form-button{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem;background-color:transparent;border:2px solid #1E3A8A;border-radius:.5rem;color:#e5e7eb;font-family:Inter,sans-serif;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:.5rem}.form-button:hover{background-color:#1e3a8a;transform:translateY(-2px);box-shadow:0 5px 15px #1e3a8a66}.contact-divider{width:2px;background:linear-gradient(to bottom,transparent,#38BDF8,transparent)}.contact-social{flex:.8;display:flex;flex-direction:column;justify-content:center}.social-subtitle{font-size:1.5rem;font-weight:700;color:#38bdf8;margin-bottom:1rem}.social-description{font-size:.95rem;color:#9ca3af;margin-bottom:2rem;line-height:1.5}.social-links{display:flex;flex-direction:column;gap:.8rem}.social-link{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;background-color:#1e3a8a33;border:2px solid rgba(56,189,248,.3);border-radius:.5rem;color:#e5e7eb;text-decoration:none;font-weight:600;transition:all .3s ease}.social-link:hover{background-color:#1e3a8a66;border-color:var(--hover-color);transform:translate(5px)}.social-link svg{transition:color .3s ease}.social-link:hover svg{color:var(--hover-color)}.social-icon{width:24px;height:24px;flex-shrink:0}.social-link:hover .social-icon path:first-child{fill:var(--hover-color)}.social-link:hover .social-icon path[fill=currentColor]{fill:var(--hover-color)}.status-message{display:flex;align-items:center;gap:.5rem;padding:.75rem;border-radius:.5rem;font-size:.9rem;font-weight:600;margin:.5rem 0}.status-message.success{background-color:#22c55e33;border:2px solid #22C55E;color:#22c55e}.status-message.error{background-color:#ef444433;border:2px solid #EF4444;color:#ef4444}.form-button:disabled{opacity:.7;cursor:not-allowed}.spinner{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:1024px){.contact-container{width:95%;padding:2.5rem}.contact-box{gap:2rem}}@media(max-width:768px){.contact-section{padding:3rem 1.5rem}.contact-container{padding:2rem}.contact-box{flex-direction:column;gap:2rem}.contact-divider{width:100%;height:2px;background:linear-gradient(to right,transparent,#38BDF8,transparent)}.contact-social{flex:1}}@media(max-width:480px){.contact-section{padding:2rem 1rem}.contact-container{padding:1.5rem}.form-subtitle,.social-subtitle{font-size:1.3rem}.social-link{padding:.875rem 1.25rem}.form-button{padding:.75rem}.social-icon{width:20px;height:20px}}@media(max-width:360px){.contact-container{padding:1.2rem}.social-link{padding:.75rem 1rem;font-size:.9rem}}.progress-keep{width:100%;display:flex;align-items:center;justify-content:center;gap:.5rem;position:fixed;bottom:0}.progress-keep-text{font-weight:100;font-size:.8rem}.cursor-glow{position:fixed;width:300px;height:300px;background:radial-gradient(circle,rgba(56,189,248,.3) 0%,transparent 60%);pointer-events:none;border-radius:50%;filter:blur(40px);z-index:0}@media screen and (max-width:850px){.cursor-glow{display:none}}
