*{margin:0;padding:0;box-sizing:border-box}:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;--primary: #135bec;--background-light: #f6f6f8;--background-dark: #101622;--gray-800: #1f2937;--gray-100: #f3f4f6}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(https://cdn.jsdelivr.net/fontsource/fonts/inter:vf@latest/latin-wght-normal.woff2) format("woff2-variations");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}section{min-height:90vh;display:flex;align-items:center;justify-content:center}html{scroll-behavior:smooth}.header{position:fixed;top:0;left:0;width:100%;z-index:1002;transition:all .3s ease;-webkit-transform:translateZ(0);transform:translateZ(0)}@supports (backdrop-filter: blur(10px)){.header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}}.header.dark{background:linear-gradient(135deg,#1a1a2ef2,#16213ef2);color:#e0e0e0;border-bottom:1px solid rgba(255,255,255,.1)}.header.light{background:linear-gradient(135deg,#f8f9faf2,#e9eceff2);color:#1a1a1a;border-bottom:1px solid rgba(0,0,0,.1);box-shadow:0 2px 10px #0000000d}.header-container{max-width:1400px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:1rem 2rem;height:72px;position:relative;z-index:1003}.logo{text-decoration:none;display:flex;align-items:center;gap:.5rem;font-weight:600;font-size:1.1rem;cursor:pointer;transition:transform .2s ease;color:inherit}.logo:hover{transform:translateY(-2px)}.logo:active{opacity:.8}.logo svg{transition:transform .3s ease}.logo:hover svg{transform:rotate(5deg)}.logo-text{background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.nav{flex:1;display:flex;justify-content:center}.nav-list{display:flex;list-style:none;gap:2rem;margin:0;padding:0}.nav-list li a{text-decoration:none;color:inherit;font-weight:500;position:relative;transition:color .3s ease;cursor:pointer}.nav-list li a:after{content:"";position:absolute;bottom:0;left:0;width:0;height:2px;background:linear-gradient(135deg,#667eea,#764ba2);transition:width .3s ease}.header.dark .nav-list .active{color:#667eea;pointer-events:none}.header.dark .nav-list li .active:after{content:"";position:absolute;left:0;width:100%;height:2px;background:linear-gradient(135deg,#667eea,#764ba2)}.header.light .nav-list li .active{color:#764ba2;pointer-events:none}.header.light .nav-list li .active:after{content:"";position:absolute;left:0;bottom:0;width:100%;height:2px;background:linear-gradient(135deg,#667eea,#764ba2)}.nav-list li a:hover:after{width:100%}.header.dark .nav-list li a:hover{color:#667eea}.header.light .nav-list li a:hover{color:#764ba2}.header-actions{display:flex;align-items:center;gap:1rem}.theme-toggle{background:none;border:none;cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .3s ease}.header.dark .theme-toggle{color:#e0e0e0}.header.light .theme-toggle{color:#1a1a1a}.theme-toggle:hover{background:#667eea1a;transform:rotate(15deg)}.hamburger{display:none;flex-direction:column;gap:4px;background:none;border:none;cursor:pointer;padding:.5rem;width:40px;height:40px;justify-content:center;align-items:center;position:relative;z-index:1003}.hamburger span{width:24px;height:2px;background:currentColor;transition:all .3s ease;border-radius:2px}.header.dark .hamburger span{background:#e0e0e0}.header.light .hamburger span{background:#1a1a1a}.hamburger.active span:nth-child(1){transform:translateY(6px) rotate(45deg)}.hamburger.active span:nth-child(2){opacity:0}.hamburger.active span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}body{margin:0;padding-top:72px}body.menu-open{overflow:hidden;position:fixed;width:100%;height:100%}.nav-overlay{display:none}@media(max-width:768px){@supports (backdrop-filter: blur(10px)){.header{-webkit-backdrop-filter:none;backdrop-filter:none}}.header-container{padding:1rem 1.5rem}.nav{position:fixed;top:72px;left:0;width:100%;height:calc(100vh - 72px);height:calc(100dvh - 72px);justify-content:flex-start;padding-top:2rem;padding-bottom:2rem;transform:translate(-100%);transform-origin:left center;transition:transform .35s cubic-bezier(.4,0,.2,1);overflow-y:auto;z-index:1001;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.header.dark .nav{background:#1a1a2e;box-shadow:2px 0 10px #0000004d}.header.light .nav{background:#fff;box-shadow:2px 0 10px #0000001a}.nav.open{transform:translate(0)}.nav-list{flex-direction:column;gap:0;width:100%;padding:0 2rem 2rem}.nav-list li{width:100%;border-bottom:1px solid rgba(102,126,234,.1)}.nav-list li:last-child{border-bottom:none}.nav-list li a{display:block;padding:1.2rem 0;font-size:1.1rem;transition:background .2s ease,color .3s ease}.nav-list li a:active{background:#667eea1a}.hamburger{display:flex}.logo-text{font-size:1rem}.nav-overlay{display:block;position:fixed;top:72px;left:0;width:100%;height:calc(100vh - 72px);height:calc(100dvh - 72px);background:#0009;z-index:1000;opacity:0;pointer-events:none;transition:opacity .35s ease;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.nav-overlay.visible{opacity:1;pointer-events:auto}}.hero{min-height:90vh;display:flex;align-items:center;justify-content:center;padding:2rem;position:relative;overflow:hidden;transition:all .3s ease}.hero.dark{background:linear-gradient(135deg,#1a1a2e,#16213e);color:#e0e0e0}.hero.light{background:linear-gradient(135deg,#f8f9fa,#e9ecef);color:#1a1a1a}.hero-container{max-width:800px;width:100%;display:flex;justify-content:center;z-index:1}.hero-content{display:flex;flex-direction:column;align-items:center;text-align:center;gap:1rem}.hero-title{font-size:clamp(2.5rem,6vw,4rem);font-weight:800;line-height:1.1;margin:0;background:linear-gradient(135deg,#667eea,#764ba2,#f093fb);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:gradientShift 3s ease infinite;background-size:200% 200%;will-change:background-position}.hero-subtitle{font-size:clamp(1.5rem,4vw,2.2rem);font-weight:600;min-height:2.2rem;margin-bottom:.5rem}.role-text{color:#667eea;animation:fadeIn .5s ease;display:inline-block}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.hero-description{font-size:1.2rem;line-height:1.7;opacity:.85;max-width:600px;margin:1rem 0}.hero-actions{display:flex;gap:1rem;flex-wrap:wrap;margin:1.5rem 0;justify-content:center}.btn{padding:1rem 2rem;border-radius:12px;font-weight:600;text-decoration:none;transition:all .3s ease;cursor:pointer;display:inline-flex;align-items:center;gap:.5rem;border:none;font-size:1.05rem;will-change:transform}.btn:focus-visible{outline:3px solid #667eea;outline-offset:3px}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 15px #667eea66}.btn-primary:hover{transform:translateY(-3px);box-shadow:0 8px 25px #667eea80}.btn-primary:active{transform:translateY(-1px)}.btn-secondary{background:transparent;color:inherit;border:2px solid rgba(102,126,234,.4)}.btn-secondary:hover{background:#667eea26;border-color:#667eea;transform:translateY(-3px)}.btn-secondary:active{transform:translateY(-1px)}.hero-social{display:flex;gap:1rem;margin-top:1rem;flex-wrap:wrap;justify-content:center}.social-link{position:relative;height:48px;min-width:48px;display:flex;align-items:center;padding:0 1.5rem;border-radius:12px;transition:all .4s cubic-bezier(.68,-.55,.265,1.55);overflow:hidden;white-space:nowrap;text-decoration:none;color:#fff;font-weight:600;font-size:.95rem;will-change:transform}.social-link:focus-visible{outline:3px solid #667eea;outline-offset:3px}.social-link svg{width:24px;height:24px;min-width:24px;color:#fff;z-index:1;transition:transform .3s ease}.social-text{opacity:0;max-width:0;transition:all .4s cubic-bezier(.68,-.55,.265,1.55);overflow:hidden}.social-link:hover .social-text,.social-link:focus-visible .social-text{opacity:1;max-width:200px;margin-left:.5rem}.social-link:hover,.social-link:focus-visible{transform:translateY(-4px);padding-right:1.5rem;box-shadow:0 8px 20px #0000004d}.social-link:active{transform:translateY(-2px)}.social-link:hover svg,.social-link:focus-visible svg{transform:scale(1.1)}.github{background:linear-gradient(135deg,#333,#24292e)}.github:hover,.github:focus-visible{box-shadow:0 8px 20px #24292e80}.linkedin{background:linear-gradient(135deg,#0077b5,#005885)}.linkedin:hover,.linkedin:focus-visible{box-shadow:0 8px 20px #0077b580}.cv{background:linear-gradient(135deg,#667eea,#764ba2)}.cv:hover,.cv:focus-visible{box-shadow:0 8px 20px #667eea80}@media(prefers-reduced-motion:reduce){.hero-title,.gradient-blob,.role-text{animation:none}*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media(max-width:768px){.hero{padding:1.5rem;min-height:85vh}.hero-title{font-size:2.8rem}.hero-subtitle{font-size:1.8rem}.hero-description{font-size:1.1rem}.hero-actions{flex-direction:column;width:100%;max-width:300px}.btn{width:100%;justify-content:center}.hero-social{width:100%;max-width:100%;gap:1rem}.social-link{min-width:56px;width:56px;height:56px;padding:0;justify-content:center}.social-link .social-text{display:none}.social-link svg{margin:0}.social-link:hover,.social-link:focus-visible{padding:0;width:56px}}@media(max-width:480px){.hero-title{font-size:2.2rem}.hero-subtitle{font-size:1.4rem}.hero-description{font-size:1rem}.blob-1,.blob-2{width:200px;height:200px}.hero-social{flex-direction:column;max-width:250px}.social-link{width:100%}}.about{padding:5rem 2rem;position:relative;overflow:hidden;transition:all .3s ease}.about.dark{background:linear-gradient(135deg,#0f0f1e,#1a1a2e);color:#e0e0e0}.about.light{background:linear-gradient(135deg,#fff,#f8f9fa);color:#2d3748}.about-container{max-width:1200px;margin:0 auto}.about-title{font-size:clamp(2.5rem,5vw,3.5rem);font-weight:700;text-align:center;margin-bottom:4rem}.about-content{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}.about-image{position:relative;display:flex;justify-content:center}.image-frame{width:400px;height:420px;border-radius:100%;padding:1rem;background:linear-gradient(135deg,#667eea,#764ba2,#f093fb);position:relative;z-index:2;box-shadow:0 20px 40px #0000004d;transition:transform .3s ease;overflow:hidden;will-change:transform}.image-frame:hover{transform:translateY(-5px) scale(1.02)}.profile-image{width:100%;height:100%;border-radius:50%;object-fit:cover;object-position:center 30%;border:4px solid transparent;background:linear-gradient(135deg,#1a1a2e,#16213e)}.about.dark .profile-image{border-color:#1a1a2e}.about.light .profile-image{border-color:#fff;background:linear-gradient(135deg,#f8f9fa,#e9ecef)}.image-glow{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:340px;height:340px;background:linear-gradient(135deg,#667eea,#764ba2,#f093fb);border-radius:50%;filter:blur(25px);opacity:.3;z-index:1;animation:pulse 4s ease-in-out infinite;will-change:opacity,transform}@keyframes pulse{0%,to{opacity:.3;transform:translate(-50%,-50%) scale(1)}50%{opacity:.5;transform:translate(-50%,-50%) scale(1.05)}}.about-text{display:flex;flex-direction:column;gap:1.5rem}.about-description{font-size:1.1rem;line-height:1.8;opacity:.9}.about-description strong{color:#667eea;font-weight:600;background:linear-gradient(120deg,#667eea26,#764ba226);padding:.1rem .4rem;border-radius:4px}.about-btn{padding:1rem 2rem;border-radius:12px;font-weight:600;text-decoration:none;transition:all .3s ease;cursor:pointer;display:inline-flex;align-items:center;gap:.5rem;border:none;font-size:1.05rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 15px #667eea66;margin-top:1rem;align-self:flex-start;will-change:transform}.about-btn:hover{transform:translateY(-3px);box-shadow:0 8px 25px #667eea80}.about-btn:active{transform:translateY(-1px)}.about-btn:focus-visible{outline:3px solid #667eea;outline-offset:3px}.about:before{content:"";position:absolute;width:300px;height:300px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;filter:blur(80px);opacity:.1;top:10%;right:10%;animation:blobMove 15s ease-in-out infinite;pointer-events:none;will-change:transform}.about:after{content:"";position:absolute;width:250px;height:250px;background:linear-gradient(135deg,#f093fb,#f5576c);border-radius:50%;filter:blur(80px);opacity:.1;bottom:10%;left:10%;animation:blobMove 15s ease-in-out infinite reverse;pointer-events:none;will-change:transform}@keyframes blobMove{0%,to{transform:translate(0) scale(1)}33%{transform:translate(30px,-30px) scale(1.1)}66%{transform:translate(-20px,20px) scale(.9)}}@media(prefers-reduced-motion:reduce){.about,.gradient-text,.image-glow,.about:before,.about:after{animation:none}*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media(max-width:968px){.about-content{grid-template-columns:1fr;gap:3rem;text-align:center}.about-image{order:-1}.image-frame{width:280px;height:280px}.image-glow{width:300px;height:300px}.about-btn{align-self:center}}@media(max-width:768px){.about{padding:3rem 1.5rem}.about-title{margin-bottom:2.5rem}.about-content{gap:2rem}.about-description{font-size:1rem}.image-frame{width:240px;height:240px}.image-glow{width:260px;height:260px}}@media(max-width:480px){.about{padding:2rem 1rem}.image-frame{width:200px;height:200px}.image-glow{width:220px;height:220px}.about-btn{width:100%;justify-content:center}.about:before,.about:after{width:150px;height:150px}}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000c;display:flex;justify-content:center;align-items:center;z-index:2000;padding:1rem;animation:fadeIn .3s ease}.modal-overlay.dark{background:#000000e6}.modal-content{background:#fff;border-radius:20px;max-width:1200px;width:100%;max-height:85vh;overflow-y:auto;position:relative;animation:slideUp .3s ease;box-shadow:0 25px 50px #0000004d}.modal-overlay.dark .modal-content{background:linear-gradient(135deg,#1a1a2e,#16213e);color:#e0e0e0;border:1px solid rgba(255,255,255,.1)}.modal-content::-webkit-scrollbar,.certificates-grid::-webkit-scrollbar{width:6px}.modal-content::-webkit-scrollbar-thumb,.certificates-grid::-webkit-scrollbar-thumb{background:#667eea99;border-radius:10px}.modal-content::-webkit-scrollbar-track,.certificates-grid::-webkit-scrollbar-track{background:transparent}.modal-header{display:flex;justify-content:space-between;align-items:flex-start;padding:2rem 2rem 1rem;border-bottom:1px solid rgba(0,0,0,.1);position:sticky;top:0;background:inherit;z-index:10;border-radius:20px 20px 0 0}.modal-overlay.dark .modal-header{border-bottom:1px solid rgba(255,255,255,.1)}.modal-title h2{font-size:2rem;font-weight:700;margin:0;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.modal-title p{margin:.5rem 0 0;opacity:.7;font-size:1.1rem}.close-btn{background:#0000001a;border:none;border-radius:50%;width:40px;height:40px;min-width:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;color:#666;flex-shrink:0}.close-btn:hover,.close-btn:focus-visible{background:#0003;transform:rotate(90deg);color:#333}.close-btn:focus-visible{outline:3px solid #667eea;outline-offset:2px}.modal-overlay.dark .close-btn{background:#ffffff1a;color:#ccc}.modal-overlay.dark .close-btn:hover,.modal-overlay.dark .close-btn:focus-visible{background:#fff3;color:#fff}.certificates-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;padding:2rem}.certificate-card{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 8px 25px #0000001a;transition:all .3s ease;cursor:pointer;border:1px solid rgba(0,0,0,.05);will-change:transform}.certificate-card:hover,.certificate-card:focus-visible{transform:translateY(-8px);box-shadow:0 15px 40px #667eea33}.certificate-card:focus-visible{outline:3px solid #667eea;outline-offset:3px}.modal-overlay.dark .certificate-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.1)}.modal-overlay.dark .certificate-card:hover,.modal-overlay.dark .certificate-card:focus-visible{box-shadow:0 15px 40px #667eea4d}.certificate-image{position:relative;width:100%;height:200px;overflow:hidden}.certificate-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.certificate-card:hover .certificate-image img,.certificate-card:focus-visible .certificate-image img{transform:scale(1.05)}.certificate-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:#667eeae6;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s ease}.certificate-card:hover .certificate-overlay,.certificate-card:focus-visible .certificate-overlay{opacity:1}.certificate-info{padding:1.5rem}.certificate-category{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:.3rem .8rem;border-radius:20px;font-size:.8rem;font-weight:600;display:inline-block;margin-bottom:.8rem}.certificate-info h3{margin:0 0 .8rem;font-size:1.2rem;font-weight:600;line-height:1.4}.certificate-meta{display:flex;justify-content:space-between;align-items:center;font-size:.9rem;opacity:.8}.institution{font-weight:600;color:#667eea}.modal-overlay.dark .institution{color:#8bb9fe}.modal-footer{padding:1.5rem 2rem 2rem;border-top:1px solid rgba(0,0,0,.1);text-align:center}.modal-overlay.dark .modal-footer{border-top:1px solid rgba(255,255,255,.1)}.drive-link{display:inline-flex;align-items:center;gap:.5rem;padding:.8rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;text-decoration:none;border-radius:12px;font-weight:600;transition:all .3s ease;box-shadow:0 4px 15px #667eea4d}.drive-link:hover,.drive-link:focus-visible{transform:translateY(-2px);box-shadow:0 8px 25px #667eea66}.drive-link:focus-visible{outline:3px solid #667eea;outline-offset:3px}.zoom-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000f2;display:flex;justify-content:center;align-items:center;z-index:2001;opacity:0;visibility:hidden;transition:all .3s ease;padding:1rem}.zoom-overlay.active{opacity:1;visibility:visible}.zoom-content{position:relative;max-width:90%;max-height:90%;background:#fff;border-radius:12px;overflow:hidden;transform:scale(.8);transition:transform .3s ease}.zoom-overlay.active .zoom-content{transform:scale(1)}.zoom-close{position:absolute;top:1rem;right:1rem;background:#000000b3;border:none;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff;z-index:10;transition:all .3s ease}.zoom-close:hover,.zoom-close:focus-visible{background:#000000e6;transform:rotate(90deg)}.zoom-close:focus-visible{outline:3px solid #667eea;outline-offset:2px}.zoomed-image{width:100%;height:auto;max-height:70vh;object-fit:contain;display:block}.zoom-info{padding:1.5rem;background:#fff;text-align:center}.zoom-info h3{margin:0 0 .5rem;font-size:1.3rem;font-weight:600}.zoom-info p{margin:0;opacity:.7}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.modal-content{margin:0;max-height:100vh;border-radius:0}.modal-header{padding:1rem;position:fixed;top:0;left:0;right:0;z-index:100;border-radius:0;background:#fff;box-shadow:0 2px 10px #0000001a}.modal-overlay.dark .modal-header{background:linear-gradient(135deg,#1a1a2e,#16213e)}.modal-title h2{font-size:1.3rem}.modal-title p{font-size:.9rem}.close-btn{position:absolute;top:1rem;right:1rem}.certificates-grid{grid-template-columns:1fr;padding:6.5rem 1.5rem 1.5rem;gap:1rem}.certificate-info{padding:1rem}.modal-footer{padding:1rem 1.5rem 1.5rem}.drive-link{width:100%;justify-content:center}.zoom-content{max-width:95%}.zoom-close{top:.5rem;right:.5rem}}@media(max-width:480px){.modal-overlay{padding:0}}.projects{padding:5rem 2rem;position:relative;overflow:hidden;transition:all .3s ease;min-height:100vh;display:flex;align-items:center}.projects.dark{background:linear-gradient(135deg,#1a1a2e,#16213e);color:#e0e0e0}.projects.light{background:linear-gradient(135deg,#f8f9fa,#e9ecef);color:#1a1a1a}.projects-container{max-width:1400px;margin:0 auto;width:100%}.projects-title{font-size:clamp(2.5rem,5vw,3.5rem);font-weight:700;text-align:center;margin-bottom:4rem}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:2rem;margin-bottom:3rem}.project-card{background:#ffffff0d;border-radius:20px;overflow:hidden;box-shadow:0 15px 35px #0003;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;height:100%;will-change:transform}.projects.light .project-card{background:#fffffff2;border:1px solid rgba(0,0,0,.1)}.project-card:hover{transform:translateY(-10px);box-shadow:0 25px 50px #0000004d}.project-image{width:100%;height:280px;overflow:hidden;position:relative;background:linear-gradient(135deg,#667eea20,#764ba220)}.project-image img{width:100%;height:100%;object-fit:cover;object-position:top center;transition:transform .5s ease}.project-card:hover .project-image img{transform:scale(1.1)}.project-content{padding:2rem;display:flex;flex-direction:column;flex:1}.project-name{font-size:1.5rem;font-weight:700;margin-bottom:.8rem;color:inherit}.project-description{font-size:.95rem;line-height:1.6;opacity:.9;margin-bottom:1.2rem;flex:1}.project-technologies{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}.tech-tag-icon{display:flex;align-items:center;justify-content:center;padding:.6rem;background:#ffffff1a;border-radius:10px;transition:all .3s ease;cursor:pointer}.projects.light .tech-tag-icon{background:#667eea1a}.tech-tag-icon:hover{transform:translateY(-3px);background:#667eea33;box-shadow:0 4px 15px #667eea4d}.tech-tag-icon svg{width:24px;height:24px;display:block}.project-links{display:flex;gap:.8rem}.project-link{display:flex;align-items:center;gap:.4rem;padding:.8rem 1.2rem;border-radius:10px;font-weight:600;text-decoration:none;transition:all .3s ease;flex:1;justify-content:center;font-size:.9rem;will-change:transform}.project-link:focus-visible{outline:3px solid #667eea;outline-offset:3px}.project-link.demo{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 15px #667eea66}.project-link.code{background:transparent;color:#667eea;border:2px solid #667eea}.projects.light .project-link.code{color:#667eea;border-color:#667eea}.project-link.demo:hover,.project-link.demo:focus-visible{transform:translateY(-2px);box-shadow:0 6px 20px #667eea80}.project-link.code:hover,.project-link.code:focus-visible{background:#667eea1a;transform:translateY(-2px)}.project-link:active{transform:translateY(0)}.projects-actions{display:flex;justify-content:center;margin-top:3rem}.view-more-btn{display:inline-flex;align-items:center;gap:.5rem;padding:1rem 2.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-size:1.05rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #667eea66;will-change:transform}.view-more-btn:hover,.view-more-btn:focus-visible{transform:translateY(-3px);box-shadow:0 8px 25px #667eea80}.view-more-btn:focus-visible{outline:3px solid #667eea;outline-offset:3px}.view-more-btn:active{transform:translateY(-1px)}.view-more-btn svg{transition:transform .3s ease}.view-more-btn:hover svg{transform:translateY(3px)}.view-more-btn[aria-expanded=true]:hover svg{transform:translateY(-3px)}.gradient-blob{position:absolute;border-radius:50%;filter:blur(100px);opacity:.15;animation:blobMove 15s ease-in-out infinite;pointer-events:none;will-change:transform}.blob-1{width:400px;height:400px;background:linear-gradient(135deg,#667eea,#764ba2);top:10%;left:10%}.blob-2{width:350px;height:350px;background:linear-gradient(135deg,#f093fb,#f5576c);bottom:10%;right:10%;animation-delay:7.5s}@media(max-width:1200px){.projects-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}}@media(max-width:968px){.projects{padding:4rem 1.5rem}.projects-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.project-image{height:240px}}@media(max-width:768px){.projects{padding:3rem 1.5rem}.projects-title{margin-bottom:3rem}.projects-grid{grid-template-columns:1fr;gap:1.5rem}.project-image{height:250px}.project-name{font-size:1.4rem}.project-description{font-size:.95rem;line-height:1.5}.project-content{padding:1.8rem}.project-technologies{gap:.6rem}.tech-tag-icon svg{width:22px;height:22px}.project-links{gap:.6rem}.project-link{padding:.75rem 1rem;font-size:.85rem}.view-more-btn{width:100%;max-width:300px;justify-content:center}}@media(max-width:480px){.projects{padding:2.5rem 1rem}.projects-title{margin-bottom:2.5rem}.projects-grid{gap:1.5rem}.project-card{border-radius:16px}.project-image{height:200px}.project-content{padding:1.5rem}.project-name{font-size:1.3rem;margin-bottom:.6rem}.project-description{font-size:.88rem;line-height:1.5;margin-bottom:1rem}.project-technologies{gap:.5rem;margin-bottom:1.2rem}.tech-tag-icon{padding:.5rem}.tech-tag-icon svg{width:20px;height:20px}.project-links{flex-direction:column;gap:.6rem}.project-link{padding:.7rem .8rem;font-size:.85rem}.project-link svg{width:16px;height:16px}.view-more-btn{width:100%;padding:.9rem 1.5rem;font-size:.95rem}}.skills{padding:5rem 2rem;position:relative;overflow:hidden;transition:all .3s ease;min-height:80vh;display:flex;align-items:center}.skills.dark{background:linear-gradient(135deg,#0f0f1e,#1a1a2e);color:#e0e0e0}.skills.light{background:linear-gradient(135deg,#fff,#f8f9fa);color:#2d3748}.skills-container{max-width:1200px;margin:0 auto;width:100%}.skills-title{font-size:clamp(2.5rem,5vw,3.5rem);font-weight:700;text-align:center;margin-bottom:4rem}.skills-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:2rem;max-width:1100px;margin:0 auto}.skill-badge{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.875rem;padding:2rem 1.25rem;background:#ffffff0d;border-radius:16px;border:2px solid rgba(102,126,234,.2);transition:all .3s cubic-bezier(.4,0,.2,1);cursor:default;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);will-change:transform}.skills.light .skill-badge{background:#ffffffe6;border:2px solid rgba(102,126,234,.15);box-shadow:0 4px 15px #0000000d}.skill-badge:hover{transform:translateY(-8px) scale(1.05);border-color:#667eea;box-shadow:0 12px 30px #667eea4d;background:#667eea26}.skills.light .skill-badge:hover{background:#667eea1a;box-shadow:0 12px 30px #667eea33}.skill-icon{display:flex;align-items:center;justify-content:center;width:52px;height:52px;flex-shrink:0}.skill-icon svg{width:100%;height:100%;transition:all .3s ease;filter:drop-shadow(0 4px 8px rgba(0,0,0,.1))}.skill-badge:hover .skill-icon svg{transform:scale(1.15) rotate(5deg);filter:drop-shadow(0 8px 16px rgba(102,126,234,.4))}.skill-name{font-weight:600;font-size:1rem;text-align:center;color:inherit;transition:color .3s ease}.skill-badge:hover .skill-name{color:#667eea}.skills.light .skill-badge:hover .skill-name{color:#764ba2}.blob-1{width:400px;height:400px;background:linear-gradient(135deg,#667eea,#764ba2);top:10%;right:10%}.blob-2{width:350px;height:350px;background:linear-gradient(135deg,#f093fb,#f5576c);bottom:10%;left:10%;animation-delay:7.5s}@media(max-width:968px){.skills{padding:4rem 1.5rem}.skills-grid{grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:1.25rem}.skill-badge{padding:1.5rem .8rem}.skill-icon{width:42px;height:42px}}@media(max-width:768px){.skills{padding:3rem 1.5rem}.skills-title{margin-bottom:3rem}.skills-grid{grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:1rem;max-width:600px}.skill-badge{padding:1.25rem .75rem;gap:.6rem}.skill-icon{width:38px;height:38px}.skill-name{font-size:.875rem}}@media(max-width:480px){.skills{padding:2.5rem 1rem;min-height:auto}.skills-title{margin-bottom:2.5rem}.skills-grid{grid-template-columns:repeat(auto-fit,minmax(90px,1fr));gap:.875rem}.skill-badge{padding:1.125rem .625rem;gap:.5rem;border-radius:12px}.skill-icon{width:32px;height:32px}.skill-name{font-size:.8rem}.blob-1,.blob-2{width:200px;height:200px}}.toast-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:9998;animation:fadeIn .3s ease}.toast-alert{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%) scale(.7);z-index:9999;width:90%;max-width:450px;border-radius:20px;box-shadow:0 20px 60px #0006;overflow:hidden;animation:toastSlideIn .4s cubic-bezier(.68,-.55,.265,1.55) forwards}.toast-alert-content{padding:2.5rem 2rem 2rem;display:flex;flex-direction:column;align-items:center;text-align:center;gap:1.5rem;position:relative}.toast-success{background:linear-gradient(135deg,#fff,#f0fff4);border:2px solid rgba(76,175,80,.3)}.toast-error{background:linear-gradient(135deg,#fff,#fff5f5);border:2px solid rgba(244,67,54,.3)}.toast-icon-wrapper{position:relative}.toast-icon-bg{width:80px;height:80px;border-radius:50%;display:flex;align-items:center;justify-content:center;position:relative;animation:iconPulse .6s ease}.toast-icon-success{background:linear-gradient(135deg,#4caf50,#81c784);box-shadow:0 8px 25px #4caf5066}.toast-icon-error{background:linear-gradient(135deg,#f44336,#e57373);box-shadow:0 8px 25px #f4433666}.toast-icon-svg{color:#fff;animation:iconDraw .6s ease .2s both}.toast-text-wrapper{width:100%}.toast-title{font-size:1.5rem;font-weight:700;margin:0 0 .5rem;animation:textSlideIn .5s ease .2s both}.toast-success .toast-title{color:#2e7d32}.toast-error .toast-title{color:#c62828}.toast-message{font-size:1rem;line-height:1.6;color:#666;margin:0;animation:textSlideIn .5s ease .3s both}.toast-close-btn{position:absolute;top:1rem;right:1rem;background:#0000000d;border:none;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;color:#666}.toast-close-btn:hover{background:#0000001a;transform:rotate(90deg)}.toast-close-btn:focus-visible{outline:2px solid #667eea;outline-offset:2px}.toast-progress{width:100%;height:4px;background:#0000001a;overflow:hidden}.toast-progress-bar{height:100%;animation:progressBar 5s linear forwards}.toast-progress-success{background:linear-gradient(90deg,#4caf50,#81c784)}.toast-progress-error{background:linear-gradient(90deg,#f44336,#e57373)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes toastSlideIn{0%{transform:translate(-50%,-50%) scale(.7);opacity:0}to{transform:translate(-50%,-50%) scale(1);opacity:1}}@keyframes iconPulse{0%{transform:scale(0);opacity:0}50%{transform:scale(1.1)}to{transform:scale(1);opacity:1}}@keyframes iconDraw{0%{stroke-dasharray:1000;stroke-dashoffset:1000}to{stroke-dasharray:1000;stroke-dashoffset:0}}@keyframes textSlideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes progressBar{0%{width:100%}to{width:0%}}@media(max-width:768px){.toast-alert{max-width:90%}.toast-alert-content{padding:2rem 1.5rem 1.5rem;gap:1.25rem}.toast-icon-bg{width:70px;height:70px}.toast-icon-svg{width:28px;height:28px}.toast-title{font-size:1.3rem}.toast-message{font-size:.95rem}}@media(max-width:480px){.toast-alert-content{padding:1.75rem 1.25rem 1.25rem;gap:1rem}.toast-icon-bg{width:60px;height:60px}.toast-icon-svg{width:24px;height:24px}.toast-title{font-size:1.2rem}.toast-message{font-size:.9rem}.toast-close-btn{width:28px;height:28px;top:.75rem;right:.75rem}.toast-close-btn svg{width:16px;height:16px}}.contact{padding:5rem 2rem;position:relative;overflow:hidden;transition:all .3s ease}.contact.dark{background:linear-gradient(135deg,#1a1a2e,#16213e);color:#e0e0e0}.contact.light{background:linear-gradient(135deg,#f8f9fa,#e9ecef);color:#1a1a1a}.contact-container{max-width:1200px;margin:0 auto;position:relative;z-index:1}.contact-title{font-size:clamp(2.5rem,5vw,3.5rem);font-weight:700;text-align:center;margin-bottom:4rem}.gradient-text{background:linear-gradient(135deg,#667eea,#764ba2,#f093fb);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:gradientShift 3s ease infinite;background-size:200% 200%;will-change:background-position}.contact-content{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start}.contact-info{display:flex;flex-direction:column;gap:2rem}.contact-subtitle{font-size:2rem;font-weight:700;color:inherit;margin-bottom:.5rem}.contact-description{font-size:1.1rem;line-height:1.7;opacity:.9;margin-bottom:1rem}.contact-links{display:flex;flex-direction:column;gap:1.5rem}.contact-link{display:flex;align-items:center;gap:1rem;padding:1.5rem;background:#ffffff0d;border-radius:16px;text-decoration:none;color:inherit;transition:all .3s ease;border:1px solid rgba(255,255,255,.1);will-change:transform}.contact.light .contact-link{background:#ffffffe6;border:1px solid rgba(0,0,0,.1)}.contact-link:hover,.contact-link:focus-visible{transform:translateY(-5px);background:#667eea1a;border-color:#667eea}.contact-link:focus-visible{outline:3px solid #667eea;outline-offset:3px}.contact-icon{display:flex;align-items:center;justify-content:center;width:50px;height:50px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;flex-shrink:0}.contact-icon svg{color:#fff}.contact-text{display:flex;flex-direction:column;gap:.25rem}.contact-label{font-size:.9rem;opacity:.7;font-weight:600;margin:0}.contact-value{font-size:1rem;font-weight:600;margin:0}.contact-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-label{font-weight:600;font-size:1rem;color:inherit;display:flex;align-items:center;gap:.25rem}.required-asterisk{color:#f44336;font-size:1.1rem}.form-input,.form-textarea{padding:1rem 1.5rem;border-radius:12px;border:2px solid rgba(255,255,255,.1);background:#ffffff0d;color:inherit;font-size:1rem;transition:all .3s ease;font-family:inherit}.contact.light .form-input,.contact.light .form-textarea{background:#ffffffe6;border:2px solid rgba(0,0,0,.1)}.form-input:focus,.form-textarea:focus{outline:none;border-color:#667eea;background:#667eea0d;transform:translateY(-2px);box-shadow:0 4px 15px #667eea33}.form-input:disabled,.form-textarea:disabled{opacity:.6;cursor:not-allowed}.form-input-error{border-color:#f44336!important;animation:shake .3s ease}.form-error{color:#f44336;font-size:.875rem;font-weight:500;display:flex;align-items:center;gap:.25rem;animation:slideDown .3s ease}.form-error:before{content:"⚠";font-size:1rem}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.form-textarea{resize:vertical;min-height:120px;max-height:300px}.form-button{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1.25rem 2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:1rem;will-change:transform}.form-button:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 8px 25px #667eea66}.form-button:focus-visible{outline:3px solid #667eea;outline-offset:3px}.form-button svg{transition:transform .3s ease}.form-button:hover:not(:disabled) svg:not(.spinner){transform:translate(3px)}.form-button:disabled{opacity:.7;cursor:not-allowed}.spinner{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.gradient-blob{position:absolute;border-radius:50%;filter:blur(80px);opacity:.1;animation:blobMove 15s ease-in-out infinite;pointer-events:none;will-change:transform}.blob-1{width:300px;height:300px;background:linear-gradient(135deg,#667eea,#764ba2);top:10%;right:10%}.blob-2{width:250px;height:250px;background:linear-gradient(135deg,#f093fb,#f5576c);bottom:10%;left:10%;animation-delay:7.5s}@keyframes gradientShift{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}@keyframes blobMove{0%,to{transform:translate(0) scale(1)}33%{transform:translate(50px,-50px) scale(1.1)}66%{transform:translate(-30px,30px) scale(.9)}}@media(prefers-reduced-motion:reduce){.gradient-text,.gradient-blob{animation:none}*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media(max-width:968px){.contact{padding:4rem 1.5rem}.contact-content{grid-template-columns:1fr;gap:3rem}.contact-info{text-align:center}.contact-link{text-align:left}}@media(max-width:768px){.contact{padding:3rem 1.5rem}.contact-title{margin-bottom:3rem}.contact-subtitle{font-size:1.7rem}.contact-links{gap:1rem}.contact-link{padding:1.25rem}}@media(max-width:480px){.contact{padding:2.5rem 1rem}.contact-title{margin-bottom:2.5rem}.contact-link{gap:.75rem}.contact-text{text-align:flex-start}.blob-1,.blob-2{width:150px;height:150px}}.footer{width:100%;padding:2.5rem 2rem;text-align:center;transition:all .3s ease;border-top:1px solid rgba(102,126,234,.1);position:relative;overflow:hidden}.footer.dark{background:linear-gradient(135deg,#1a1a2e,#16213e);color:#e0e0e0}.footer.light{background:linear-gradient(135deg,#f8f9fa,#e9ecef);color:#1a1a1a;box-shadow:0 -2px 10px #0000000d}.footer-container{max-width:1400px;margin:0 auto;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2rem;width:100%}.footer-content{display:flex;align-items:center;justify-content:center;gap:.5rem;font-size:.95rem;opacity:.85;flex-wrap:wrap}.footer-heart{color:#e74c3c;animation:heartbeat 1.5s ease-in-out infinite;display:inline-block;font-size:1.1rem;will-change:transform}.footer-heart.no-animation{animation:none}.footer-author{font-weight:600;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;transition:transform .2s ease;display:inline-block;cursor:default}.footer-author:hover{transform:translateY(-2px)}.footer-social{display:flex;align-items:center;justify-content:center;gap:2rem;flex-wrap:wrap}.footer-social-link{display:flex;align-items:center;gap:.5rem;text-decoration:none;color:inherit;font-size:.9rem;font-weight:500;transition:all .3s ease;opacity:.8;position:relative}.footer-social-link:after{content:"";position:absolute;bottom:-2px;left:0;width:0;height:2px;background:linear-gradient(135deg,#667eea,#764ba2);transition:width .3s ease}.footer-social-link:hover,.footer-social-link:focus-visible{opacity:1;color:#667eea;transform:translateY(-2px)}.footer.light .footer-social-link:hover,.footer.light .footer-social-link:focus-visible{color:#764ba2}.footer-social-link:hover:after,.footer-social-link:focus-visible:after{width:100%}.footer-social-link:focus-visible{outline:2px solid #667eea;outline-offset:3px;border-radius:4px}.footer-social-link svg{color:#667eea;transition:transform .3s ease}.footer.light .footer-social-link svg{color:#764ba2}.footer-social-link:hover svg,.footer-social-link:focus-visible svg{transform:scale(1.15)}@keyframes heartbeat{0%,to{transform:scale(1)}10%,30%{transform:scale(1.1)}20%,40%{transform:scale(1)}}@media(prefers-reduced-motion:reduce){.footer-heart{animation:none}*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media(max-width:768px){.footer{padding:2rem 1rem}.footer-container{gap:1.5rem}.footer-content{font-size:.9rem}.footer-social{gap:1.5rem}.footer-social-link{font-size:.85rem}}@media(max-width:480px){.footer{padding:1.75rem 1rem}.footer-container{gap:1.25rem}.footer-content{font-size:.85rem;gap:.4rem}.footer-heart{font-size:1rem}.footer-social{gap:1.25rem}.footer-social-link{font-size:.8rem}.footer-social-link svg{width:16px;height:16px}}
