.appbar{display:flex;justify-content:space-between;align-items:center;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid rgba(63,97,136,.3);color:#e8f4fd;padding:.6rem 2rem;height:60px;font-size:1.2rem;font-weight:700;box-shadow:0 4px 20px #0000004d,0 0 40px #008ae01a;position:fixed;top:0;left:0;width:100%;z-index:1000;transition:all .3s ease}.appbar-logo{display:flex;align-items:center;gap:1rem}.appbar img{height:45px;border-radius:50%;border:2px solid #008AE0;box-shadow:0 0 15px #008ae04d;transition:transform .3s ease,box-shadow .3s ease}.appbar img:hover{transform:scale(1.1);box-shadow:0 0 25px #008ae099}.appbar h1{font-size:1.4rem;margin:0;padding:.3rem .6rem;background:linear-gradient(45deg,#008ae0,#3f6188);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:800;text-shadow:none;border-radius:8px;border:1px solid rgba(0,138,224,.2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background-color:#3f61881a;transition:all .3s ease}.appbar h1:hover{background:linear-gradient(45deg,#3f6188,#008ae0);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;transform:translateY(-2px);background-color:#008ae026}.appbar-buttons{display:flex;justify-content:flex-end;align-items:center;gap:.8rem;position:relative;right:2.5rem}.appbar-buttons button{background:#3f618833;color:#e8f4fd;border:1px solid rgba(0,138,224,.3);border-radius:18px;cursor:pointer;font-size:.9rem;font-weight:600;padding:.5rem 1rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease;position:relative;overflow:hidden;text-decoration:none}.appbar-buttons button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(0,138,224,.3),transparent);transition:left .6s ease}.appbar-buttons button:hover:before{left:100%}.appbar-buttons button:hover{background:linear-gradient(45deg,#008ae033,#3f61884d);border-color:#008ae0;color:#fff;transform:translateY(-2px);box-shadow:0 5px 15px #008ae04d}.appbar.scrolled{background:linear-gradient(135deg,#071b33fa,#0a2847fa,#071b33fa);box-shadow:0 8px 30px #0006,0 0 60px #008ae026;height:55px}.appbar-buttons a{text-decoration:none}@media (max-width: 768px){.appbar{padding:.5rem 1.5rem;height:55px}.appbar img{height:38px}.appbar h1{font-size:1.2rem;padding:.25rem .5rem}.appbar-buttons{gap:.5rem}.appbar-buttons button{font-size:.8rem;padding:.4rem .8rem}}@media (max-width: 480px){.appbar{padding:.4rem 1rem;height:50px}.appbar img{height:35px}.appbar h1{font-size:1rem;padding:.2rem .4rem}.appbar-buttons{gap:.3rem}.appbar-buttons button{font-size:.75rem;padding:.3rem .6rem}}.home{display:flex;justify-content:center;align-items:center;min-height:100vh;padding:2rem;gap:4rem;padding-top:10px}.home-content{flex:1;max-width:600px;z-index:1;animation:slideInLeft .8s ease-out}.home-text{display:flex;flex-direction:column;gap:2rem}.greeting h1{font-size:3.3rem;color:#e8f4fd;line-height:1.2;font-weight:700;animation:slideInLeft 1s ease-out .2s both}.name-highlight{background:linear-gradient(45deg,#008ae0,#3f6188);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:800}.role-container{margin-bottom:1rem}.role-container h2{font-size:2.2rem;color:#b8d4e3;font-weight:500;animation:slideInLeft 1.2s ease-out .4s both}.role-highlight{color:#008ae0;font-weight:700;text-shadow:0 0 20px rgba(0,138,224,.5)}.description{font-size:1.3rem;color:#e8f4fd;line-height:1.8;margin-bottom:1.5rem;text-align:justify;padding:1.5rem;background:#3f61881a;border-radius:15px;border:1px solid rgba(63,97,136,.3);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 8px 25px #008ae01a;animation:slideInLeft 1.4s ease-out .6s both}.description b{color:#008ae0;font-weight:700;text-shadow:0 0 10px rgba(0,138,224,.3)}.technologies-preview{display:flex;gap:1rem;margin-bottom:2rem;flex-wrap:wrap;justify-content:center;animation:slideInLeft 1.6s ease-out .8s both}.tech-item{background:linear-gradient(145deg,#3f618833,#008ae033);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(0,138,224,.3);color:#e8f4fd;padding:1rem 2rem;border-radius:30px;font-size:1.1rem;font-weight:600;box-shadow:0 4px 15px #008ae04d;transition:all .4s cubic-bezier(.175,.885,.32,1.275);position:relative;overflow:hidden;cursor:default}.tech-item:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);transition:left .6s ease}.tech-item:hover:before{left:100%}.tech-item:hover{transform:translateY(-5px) scale(1.05);background:linear-gradient(145deg,#008ae04d,#3f61884d);border-color:#008ae0;box-shadow:0 8px 25px #008ae080;color:#fff}.tech-item:nth-child(1){animation:slideInTech .8s ease-out .8s both}.tech-item:nth-child(2){animation:slideInTech .8s ease-out .9s both}.tech-item:nth-child(3){animation:slideInTech .8s ease-out 1s both}.tech-item:nth-child(4){animation:slideInTech .8s ease-out 1.1s both}.tech-item:nth-child(5){animation:slideInTech .8s ease-out 1.2s both}.cta-section{margin-top:2rem;animation:slideInLeft 1.8s ease-out 1s both}.home-image{flex:1;display:flex;justify-content:center;align-items:center;max-width:500px;animation:slideInLeft 1.2s ease-out .3s both}.image-container{position:relative;width:100%;max-width:400px}.image-container img{width:100%;height:auto;border-radius:20px;box-shadow:0 20px 40px #008ae04d;border:3px solid #3F6188;transition:transform .3s ease,box-shadow .3s ease}.image-container img:hover{transform:scale(1.05) rotate(2deg);box-shadow:0 30px 60px #008ae080}.image-decoration{position:absolute;top:-20px;right:-20px;width:100px;height:100px;background:linear-gradient(45deg,#008ae0,#3f6188);border-radius:50%;opacity:.3;z-index:-1;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}@keyframes appear{0%{opacity:0;clip-path:inset(100% 100% 0 0)}to{opacity:1;clip-path:inset(0 0 0 0)}}@media (max-width: 1400px){.home{gap:3rem;padding:1.5rem;padding-top:85px}.greeting h1{font-size:3rem}.role-container h2{font-size:2rem}.description{font-size:1.2rem;padding:1.2rem}.tech-item{padding:.8rem 1.6rem;font-size:1rem}.tech-item:hover{transform:translateY(-3px) scale(1.03)}}@media (max-width: 768px){.home{flex-direction:column;gap:3rem;padding:1.5rem;padding-top:75px;text-align:center}.home-content{order:2;max-width:100%}.home-image{order:1;max-width:350px}.greeting h1{font-size:2.5rem;text-align:center}.role-container h2{font-size:1.8rem;text-align:center}.description{font-size:1.1rem;text-align:justify}.technologies-preview{justify-content:center}.image-decoration{display:none}}@media (max-width: 480px){.home{padding:1rem .5rem;padding-top:65px;gap:2rem}.home-image{max-width:280px}.greeting h1{font-size:2rem;line-height:1.1}.role-container h2{font-size:1.5rem}.description{font-size:1rem;padding:1rem;line-height:1.6}.technologies-preview{gap:.5rem}.tech-item{padding:.7rem 1.4rem;font-size:.9rem}.tech-item:hover{transform:translateY(-2px) scale(1.02)}.tech-item:nth-child(n){animation:none!important}.image-container img{border-radius:15px}.block{animation:none!important}}@keyframes slideInTech{0%{transform:translate(-50px) scale(.8);opacity:0}60%{transform:translate(5px) scale(1.05);opacity:.8}to{transform:translate(0) scale(1);opacity:1}}.home-buttons{display:flex;justify-content:center;align-items:center;gap:2rem;margin-top:1rem;flex-wrap:wrap}.home-buttons button{background:linear-gradient(145deg,#3f618833,#008ae033);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid rgba(0,138,224,.3);border-radius:25px;padding:1rem 1.8rem;color:#e8f4fd;cursor:pointer;font-size:1.1rem;font-weight:600;margin:0;box-shadow:0 8px 25px #008ae033;align-items:center;display:flex;gap:.5rem;transition:all .4s cubic-bezier(.175,.885,.32,1.275);position:relative;overflow:hidden}.home-buttons a{text-decoration:none;color:inherit}.home-buttons button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .6s ease}.home-buttons button:hover:before{left:100%}.home-buttons img{width:24px;height:24px;filter:brightness(1.2);transition:transform .3s ease}.home-buttons button:hover{background:linear-gradient(145deg,#008ae04d,#3f61884d);border-color:#008ae0;transform:translateY(-5px) scale(1.05);box-shadow:0 15px 40px #008ae066;color:#fff}.home-buttons button:hover img{transform:scale(1.1)}.home-buttons button:active{transform:translateY(-2px) scale(1.02)}@media (max-width: 1400px){.home-buttons{gap:1.5rem}.home-buttons button{padding:.8rem 1.4rem;font-size:1rem}.home-buttons img{width:22px;height:22px}}@media (max-width: 768px){.home-buttons{gap:1rem;margin-top:1.5rem}.home-buttons button{padding:.7rem 1.2rem;font-size:.95rem;border-radius:20px}.home-buttons img{width:20px;height:20px}}@media (max-width: 480px){.home-buttons{gap:.8rem;flex-direction:column;width:100%}.home-buttons button{padding:.8rem 1.5rem;font-size:.9rem;width:100%;max-width:250px;justify-content:center}.home-buttons img{width:18px;height:18px}.home-buttons button:hover{transform:translateY(-3px) scale(1.02)}}.about{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#071b33,#0a2847,#071b33);padding:1rem;gap:3rem;padding-top:100px}.about-image{position:relative;display:flex;justify-content:center;align-items:center;flex:1;max-width:350px;animation:slideInLeft .8s ease-out}.about-image img{width:100%;height:auto;max-height:420px;object-fit:cover;border-radius:18px;box-shadow:0 15px 35px #008ae040;border:2px solid #3F6188;transition:transform .3s ease,box-shadow .3s ease}.about-image img:hover{transform:translateY(-8px) scale(1.02);box-shadow:0 25px 50px #008ae066}.image-overlay{position:absolute;bottom:-15px;left:50%;transform:translate(-50%);display:flex;gap:8px}.tech-badge{background:linear-gradient(45deg,#008ae0,#3f6188);color:#fff;padding:6px 12px;border-radius:16px;font-size:.8rem;font-weight:700;box-shadow:0 3px 12px #008ae040;transition:transform .3s ease;animation:slideInLeft 1.7s ease-out .9s both}.tech-badge:hover{transform:translateY(-2px)}.about-content{flex:1;max-width:550px;animation:slideInLeft 1s ease-out .2s both}.about-header{margin-bottom:1.5rem;animation:slideInLeft .9s ease-out .1s both}.about-header h2{color:#008ae0;font-size:2.5rem;margin:0 0 .8rem;font-weight:700;background:linear-gradient(45deg,#008ae0,#3f6188);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.underline{width:60px;height:3px;background:linear-gradient(45deg,#008ae0,#3f6188);border-radius:2px;margin-bottom:.8rem;animation:slideInLeft 1.1s ease-out .3s both}.about-text{display:flex;flex-direction:column;gap:1.2rem;margin-bottom:2.5rem;animation:slideInLeft 1.3s ease-out .5s both}.about-text p{font-size:1rem;color:#e8f4fd;line-height:1.7;text-align:justify;padding:1.2rem;background:#3f61881a;border-radius:12px;border:1px solid rgba(63,97,136,.3);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:transform .3s ease,box-shadow .3s ease;animation:slideInLeft 1.5s ease-out .7s both}.about-text p:hover{transform:translateY(-3px);box-shadow:0 8px 25px #008ae026}.intro{font-size:1.25rem!important;font-weight:500;background:#008ae01a!important;border:2px solid rgba(0,138,224,.3)!important}.highlight{color:#008ae0;font-weight:700;font-size:1.1em}b{color:#008ae0;font-weight:700;font-size:1.05em;text-shadow:0 0 8px rgba(0,138,224,.25)}@media (max-width: 1400px){.about{gap:2rem;padding:1.2rem;padding-top:90px}.about-header h2{font-size:2.2rem}.about-text p{font-size:.95rem;padding:1rem}.intro{font-size:1.1rem!important}.tech-badge{font-size:.75rem;padding:5px 10px}.about-image{max-width:320px}.about-image img{max-height:380px}}@media (max-width: 768px){.about{flex-direction:column;gap:2.5rem;padding:1.5rem 1rem;padding-top:80px;min-height:auto}.about-image{max-width:280px;order:1}.about-image img{max-height:320px}.about-content{order:2;max-width:100%}.about-header h2{font-size:2rem;text-align:center}.underline{margin:0 auto .8rem}.about-text p{font-size:.9rem;padding:.9rem}.intro{font-size:1.05rem!important}.image-overlay{position:static;transform:none;justify-content:center;margin-top:.8rem}}@media (max-width: 480px){.about{padding:1rem .5rem;padding-top:70px;gap:1.5rem}.about-image{max-width:220px}.about-image img{border-radius:12px;max-height:280px}.about-header h2{font-size:1.6rem}.about-text{gap:.8rem;margin-bottom:1.5rem}.about-text p{font-size:.85rem;padding:.7rem;line-height:1.5}.intro{font-size:.95rem!important}.tech-badge{font-size:.65rem;padding:3px 6px}.highlight{font-size:1.05em}b{font-size:.95em}.block{animation:none!important}}@keyframes slideInLeft{0%{transform:translate(-100px);opacity:0}to{transform:translate(0);opacity:1}}.icons-contact{display:flex;justify-content:center;align-items:center;margin-top:2rem;gap:1.5rem;flex-wrap:wrap}.icons-contact a{position:relative;display:flex;justify-content:center;align-items:center;text-decoration:none;transition:transform .3s ease}.icons-contact a img{width:60px;height:60px;border-radius:50%;background:linear-gradient(145deg,#3f6188,#008ae0);padding:12px;box-shadow:0 8px 25px #008ae04d;border:2px solid rgba(255,255,255,.1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .4s cubic-bezier(.175,.885,.32,1.275);filter:brightness(1.1)}.icons-contact a:hover{transform:translateY(-8px) scale(1.1)}.icons-contact a img:hover{background:linear-gradient(145deg,#008ae0,#3f6188);box-shadow:0 15px 40px #008ae099;border-color:#ffffff4d;filter:brightness(1.3)}.icons-contact a:nth-child(1) img{animation:subtlePulse 3s ease-in-out infinite;animation-delay:0s}.icons-contact a:nth-child(2) img{animation:subtlePulse 3s ease-in-out infinite;animation-delay:.5s}.icons-contact a:nth-child(3) img{animation:subtlePulse 3s ease-in-out infinite;animation-delay:1s}.icons-contact a:nth-child(4) img{animation:subtlePulse 3s ease-in-out infinite;animation-delay:1.5s}@keyframes subtlePulse{0%,to{box-shadow:0 8px 25px #008ae04d}50%{box-shadow:0 8px 25px #008ae080}}@media (max-width: 768px){.icons-contact{margin-top:1.5rem;gap:1rem}.icons-contact a img{width:50px;height:50px;padding:10px}}@media (max-width: 480px){.icons-contact{margin-top:1rem;gap:.8rem}.icons-contact a img{width:45px;height:45px;padding:8px}.icons-contact a:hover{transform:translateY(-5px) scale(1.05)}}*{margin:0;padding:0;scroll-behavior:smooth}.app{height:100vh;overflow:auto;background:linear-gradient(135deg,#071b33,#0a2847,#071b33)}.app::-webkit-scrollbar{display:none}.projects{padding:120px 2rem 4rem;color:#fff;background:linear-gradient(135deg,#071b33,#0a2847,#071b33);min-height:100vh}.projects-header{text-align:center;margin-bottom:4rem;max-width:800px;margin-left:auto;margin-right:auto;animation:slideInFromTop .8s ease-out both;animation-timeline:view();animation-range:entry 0% cover 30%}.projects-header h1{font-size:3.5rem;margin-bottom:1rem;background:linear-gradient(45deg,#008ae0,#3f6188);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:700}.projects-header p{font-size:1.3rem;color:#b8d4e3;line-height:1.6}.projects-grid{max-width:1400px;margin:0 auto;display:flex;flex-direction:column;gap:4rem;padding:0 2rem}.project-card{display:flex;align-items:center;gap:3rem;padding:2.5rem;background:#3f61881a;border-radius:25px;border:1px solid rgba(63,97,136,.3);-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);transition:all .6s cubic-bezier(.175,.885,.32,1.275);position:relative;overflow:hidden;max-width:900px;box-shadow:0 10px 30px #008ae01a;opacity:0;transform:translateY(50px)}.project-card:nth-child(odd){margin-left:0;margin-right:auto;animation:slideInFromLeftScroll .8s ease-out both;animation-timeline:view();animation-range:entry 0% cover 40%}.project-card:nth-child(2n){margin-left:auto;margin-right:0;flex-direction:row-reverse;animation:slideInFromRightScroll .8s ease-out both;animation-timeline:view();animation-range:entry 0% cover 40%}.project-card:nth-child(1){animation-delay:.2s}.project-card:nth-child(2){animation-delay:.4s}.project-card:nth-child(3){animation-delay:.6s}.project-card:nth-child(4){animation-delay:.8s}.project-card:before{content:"";position:absolute;top:0;left:0;right:0;height:5px;background:linear-gradient(45deg,#008ae0,#3f6188)}.project-card:hover{transform:translateY(-8px) scale(1.02);box-shadow:0 20px 40px #008ae04d}.project-image{flex:0 0 45%;position:relative;border-radius:20px;overflow:hidden;height:280px;box-shadow:0 15px 35px #008ae040}.project-screenshot{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.project-image:hover .project-screenshot{transform:scale(1.1)}.image-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#071b3367,#0a284769,#071b336c);display:flex;align-items:center;justify-content:center;opacity:0;transform:translate(-100%);transition:opacity .4s ease,transform .4s ease;text-align:center}.project-image:hover .image-overlay{opacity:1;transform:translate(0)}.view-project{background:#fff;color:#008ae0;padding:1rem 2rem;border-radius:25px;text-decoration:none;font-weight:600;transition:transform .5s ease .1s,opacity .5s ease .1s;white-space:nowrap;position:relative;z-index:1;transform:translate(-50px);opacity:0}.project-image:hover .view-project{transform:translate(0);opacity:1}.project-content{flex:1;display:flex;flex-direction:column;gap:1.5rem;padding:0 1.5rem}.project-card:nth-child(2n) .project-content{text-align:right}.project-card:nth-child(2n) .tech-stack{justify-content:flex-end}.project-card:nth-child(2n) .project-actions{justify-content:flex-end}.project-header{margin-bottom:1rem}.project-header h3{font-size:2.2rem;color:#008ae0;margin:0;font-weight:700}.project-description{font-size:1.1rem;line-height:1.8;color:#e8f4fd;margin:0}.project-technologies h4{font-size:1.1rem;color:#008ae0;margin-bottom:1rem;font-weight:600}.tech-stack{display:flex;gap:1rem;flex-wrap:wrap}.tech-item{background:#3f618833;border-radius:10px;padding:.5rem;transition:transform .3s ease,background .3s ease}.tech-item:hover{transform:translateY(-3px);background:#008ae04d}.tech-item img{width:40px;height:40px;object-fit:contain}.project-actions{display:flex;gap:1rem;margin-top:1rem}.github-link{transition:transform .3s ease}.github-link:hover{transform:scale(1.05)}.github-link img{border-radius:8px;box-shadow:0 4px 15px #008ae04d}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;background:linear-gradient(135deg,#071b33,#0a2847,#071b33);color:#fff}.loading-spinner{width:60px;height:60px;border:4px solid rgba(0,138,224,.3);border-top:4px solid #008AE0;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes slideInFromLeft{0%{transform:translate(-100px);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideInFromRight{0%{transform:translate(100px);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideInFromLeftScroll{0%{opacity:0;transform:translate(-100px) translateY(30px)}to{opacity:1;transform:translate(0) translateY(0)}}@keyframes slideInFromRightScroll{0%{opacity:0;transform:translate(100px) translateY(30px)}to{opacity:1;transform:translate(0) translateY(0)}}@keyframes slideInFromTop{0%{opacity:0;transform:translateY(-50px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 1400px){.projects{padding:100px 1.5rem 3rem}.projects-header h1{font-size:3rem}.projects-grid{gap:3rem;padding:0 1rem}.project-card{gap:2rem;padding:2rem;max-width:800px}.project-header h3{font-size:2rem}.project-image{height:250px}}@media (max-width: 768px){.projects{padding:90px 1rem 2rem}.projects-header{margin-bottom:3rem}.projects-header h1{font-size:2.5rem}.projects-header p{font-size:1.1rem}.projects-grid{padding:0}.project-card{flex-direction:column!important;gap:2rem;text-align:center!important;margin:0 auto!important;max-width:100%}.project-card:nth-child(2n){flex-direction:column!important}.project-content{text-align:center!important;padding:0}.project-card:nth-child(2n) .project-content{text-align:center!important}.project-header{justify-content:center;text-align:center}.project-header h3{font-size:1.8rem}.project-image{flex:none;width:100%;height:200px}.tech-stack{justify-content:center!important}.project-card:nth-child(2n) .tech-stack{justify-content:center!important}.project-actions{justify-content:center!important}.project-card:nth-child(2n) .project-actions{justify-content:center!important}}@media (max-width: 480px){.projects{padding:80px .5rem 1.5rem}.projects-header h1{font-size:2rem}.projects-header p{font-size:1rem}.projects-grid{gap:2rem}.project-card{padding:1rem;gap:1.5rem}.project-header h3{font-size:1.5rem}.project-description{font-size:1rem;line-height:1.6}.project-image{height:150px}.tech-item img{width:30px;height:30px}.view-project{padding:.8rem 1.5rem;font-size:.9rem}.project-technologies h4{font-size:1rem}.project-card:nth-child(n){animation:none!important}}
