@import"https://fonts.googleapis.com/css2?family=Alumni+Sans+SC:wght@400;500;600;700&display=swap";@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&display=swap";:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}body{font-family:Inter,sans-serif;background-color:var(--background-color);color:var(--text-color-dark);line-height:1.6;margin:0;padding:0;min-height:100vh;overflow-x:hidden;display:flex;justify-content:center;align-items:center}.app-container{width:100%;height:100vh;display:flex;justify-content:center;align-items:center}.app-container.loaded{opacity:1;transform:translateY(0)}.hero-section{width:100%;max-width:900px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:3rem;padding:6rem 2rem}.hero-content{display:flex;flex-direction:column;align-items:center;gap:.7rem;width:100%}.hero-title{font-family:Merriweather,serif;font-size:5.8rem;line-height:1.1;margin-bottom:.5rem;letter-spacing:-2px;color:var(--text-color-dark);font-weight:700;position:relative}.hero-title:after{content:"_";display:inline-block;margin-left:5px;color:var(--text-color-dark);animation:blink 1s steps(1,start) infinite}.hero-subtitle{font-family:Alumni Sans SC,sans-serif;font-size:1.8rem;font-weight:400;color:var(--color-secondary);margin-bottom:1rem;opacity:.9}.hero-description{font-family:Inter,sans-serif;font-size:1.2rem;color:var(--text-color-dark);max-width:700px;line-height:1.8;font-weight:300;opacity:.8}.social-links{display:flex;justify-content:center;gap:1.8rem;margin-top:3rem}.social-link{color:var(--link-color);font-size:2.2rem;transition:color .3s ease}.social-link:hover{color:var(--link-hover-color);transform:none}.profile-image-container{display:none}@media (max-width: 768px){body{padding:1rem}.hero-section{padding:5rem 1rem;gap:2rem}.hero-title{font-size:4.5rem;letter-spacing:-1px}.hero-subtitle{font-size:1.4rem}.hero-description{font-size:1rem;max-width:90%}.hero-title:after{font-size:3rem}.social-links{gap:1.5rem}.social-link{font-size:2rem}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .3s ease}.modal-content{background:#fff;border-radius:20px;padding:2rem;width:90%;max-width:1200px;max-height:90vh;overflow-y:auto;position:relative;animation:slideIn .3s ease;box-shadow:0 10px 30px #0003}.modal-close{position:absolute;top:1rem;right:1rem;background:none;border:none;color:var(--text-color-dark);font-size:1.5rem;cursor:pointer;padding:.5rem;transition:all .3s ease;z-index:1}.modal-close:hover{transform:scale(1.1);color:var(--color-primary)}@keyframes slideIn{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-content::-webkit-scrollbar{width:8px}.modal-content::-webkit-scrollbar-track{background:#0000001a;border-radius:4px}.modal-content::-webkit-scrollbar-thumb{background:#0003;border-radius:4px}.modal-content::-webkit-scrollbar-thumb:hover{background:#0000004d}.snap-container{height:100vh;width:100vw;overflow-y:scroll;scroll-snap-type:y mandatory;scroll-behavior:smooth;position:relative;background:var(--background-color)}.snap-section{min-height:100vh;width:100vw;scroll-snap-align:start;display:flex;align-items:center;justify-content:center;position:relative;transition:opacity .7s cubic-bezier(.4,0,.2,1),transform .7s cubic-bezier(.4,0,.2,1);padding:0;margin:0}.hero-snap{background:var(--background-color)}.projects-snap{background:#fff}.main-header{position:fixed;top:0;left:0;width:100vw;height:64px;background:#fffffff2;box-shadow:0 2px 12px #0000000a;display:flex;align-items:center;justify-content:space-between;padding:0 2.5rem;z-index:100;transition:background .3s}.header-logo{font-family:Merriweather,serif;font-size:2rem;color:var(--color-primary);font-weight:700;letter-spacing:-1px;display:flex;align-items:center}.header-cursor{font-family:Merriweather,serif;color:var(--color-primary);margin-left:2px;animation:blink 1s steps(1,start) infinite}.header-nav{display:flex;align-items:center;gap:2rem}.header-link{font-family:Inter,sans-serif;font-size:1.1rem;color:var(--color-secondary);text-decoration:none;font-weight:500;padding:.5rem 1.2rem;border-radius:8px;transition:background .2s,color .2s}.header-link-active,.header-link:hover{background:var(--color-secondary);color:#fff}.projects-section{width:100%;max-width:900px;margin:0 auto;padding:2rem 1rem;text-align:center}.projects-section h2{font-family:Merriweather,serif;font-size:2.2rem;color:var(--color-secondary);margin-bottom:2rem}@media (max-width: 768px){.main-header{height:52px;padding:0 1rem}.header-logo{font-size:1.3rem}.header-nav{gap:1rem}.header-link{font-size:1rem;padding:.3rem .7rem}.projects-section{padding:1rem .2rem}}:root{--color-primary: #0e91a1;--color-secondary: #854178;--color-accent-1: #ea7c64;--color-accent-2: #4bbcb6;--background-color: #f8fafc;--text-color-dark: #1e293b;--text-color-light: #ffffff;--link-color: var(--color-primary);--link-hover-color: var(--color-accent-1)}*{margin:0;padding:0;box-sizing:border-box}.hero-container{min-height:100vh;width:100%;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:2rem;position:relative;overflow:hidden;background-color:var(--background-color)}.hero-section{display:flex;flex-direction:column;justify-content:space-between;align-items:center;width:100%;max-width:800px;margin:0 auto;gap:2rem;z-index:1;height:100vh;padding:2rem 0;text-align:center;position:relative}.hero-content{display:flex;flex-direction:column;align-items:center;text-align:center;width:100%;margin-top:auto}.hero-text{display:flex;flex-direction:column;align-items:center;gap:0}.hero-title{font-family:Merriweather,serif;font-size:4rem;font-weight:700;color:#222c;margin:0;cursor:pointer;transition:all .3s ease;position:relative;padding:.2rem .5rem;border-radius:4px;display:inline-block;animation:subtlePulse 2s ease-in-out}@keyframes subtlePulse{0%{transform:scale(1);opacity:.8}50%{transform:scale(1.02);opacity:1}to{transform:scale(1);opacity:1}}.hero-title:after{content:"_";display:inline-block;margin-left:3px;color:#222c;animation:blink 1s steps(1,start) infinite;transition:color .3s ease;font-weight:300}.hero-title:hover{color:#0e91a1;background:none}.hero-title:hover:after{color:#222c}@keyframes blink{0%{opacity:1}50%{opacity:0}to{opacity:1}}.hero-title::selection{background:var(--color-primary);color:var(--text-color-dark)}.hero-subtitle{font-family:Alumni Sans SC,sans-serif;font-size:1.5rem;color:#8541a1;opacity:.9;margin:0}.hero-description{font-family:Inter,sans-serif;font-size:1rem;color:var(--text-color-dark);max-width:600px;line-height:1.6;opacity:.8;margin:0}.social-links{display:flex;justify-content:center;gap:1.5rem;margin-top:auto;padding-bottom:2rem;width:100%}.social-link{color:#0e91a1;font-size:1.5rem;transition:color .3s ease}.social-link:hover{color:#ea7c64;transform:translateY(-3px)}@media (max-width: 768px){.hero-title{font-size:2.5rem}.hero-subtitle{font-size:1.2rem}.hero-description{font-size:.9rem;padding:0 1rem}.social-links{gap:1rem}.social-link{font-size:1.2rem}}.sobre-container{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;padding:2rem;color:var(--text-color-dark);overflow-y:auto;border-color:#0e91a1}.sobre-content{width:100%;max-width:1000px;display:flex;align-items:center;gap:3rem;border-color:#0e91a1}.sobre-image{flex-shrink:0;width:300px;height:300px;border-radius:15px;overflow:hidden;border:3px solid #0e91a1;transition:transform .3s ease-in-out,box-shadow .3s ease-in-out}.sobre-image:hover{transform:scale(1.05);box-shadow:0 15px 30px #000}.profile-image{display:block;width:100%;height:100%;object-fit:cover;border:3px solid #0e91a1;box-shadow:0 0 0 2px #0e91a1}.sobre-info{flex-grow:1;display:flex;flex-direction:column;gap:1.5rem}.sobre-info h2{font-size:2.5rem;font-weight:700;color:#0e91a1;margin:0;font-family:Alumni Sans SC,sans-serif;text-transform:uppercase;letter-spacing:1px;border-bottom:2px solid #0e91a1;padding-bottom:.5rem}.sobre-text{display:flex;flex-direction:column;gap:1.5rem}.sobre-text p{font-size:1.1rem;line-height:1.6;color:var(--text-color-dark);opacity:.9;margin:0 0 1rem;font-family:Inter,sans-serif;text-align:justify}.sobre-text p:last-child{margin-bottom:0}@media (max-width: 1024px){.sobre-content{flex-direction:column;align-items:center;gap:2rem}.sobre-image{max-width:300px}.sobre-info{text-align:center}}@media (max-width: 768px){.sobre-container{padding:1rem}.sobre-content{flex-direction:column;gap:2rem}.sobre-image{width:200px;height:200px;border-radius:10px}.sobre-info{gap:1rem}.sobre-info h2{font-size:2rem;text-align:center;border-bottom:none;padding-bottom:0}.sobre-text p{font-size:1rem}}.trajetoria-container{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;padding:2rem;color:var(--text-color-dark);overflow-y:auto}.trajetoria-content{width:100%;max-width:1200px;display:flex;flex-direction:column;gap:3rem}.trajetoria-section{display:flex;flex-direction:column;gap:1.5rem}.trajetoria-section h2{font-size:2.5rem;font-weight:700;color:#0e91a1;margin:0;font-family:Alumni Sans SC,sans-serif;text-transform:uppercase;letter-spacing:1px;border-bottom:2px solid #0e91a1;padding-bottom:.5rem;display:flex;align-items:center;gap:1rem}.trajetoria-item{display:flex;flex-direction:column;gap:.5rem;padding:1.5rem;background:linear-gradient(145deg,#fff,#f8fafc);border-radius:15px;box-shadow:0 5px 15px #0000000d;border:1px solid #0e91a1;transition:transform .3s ease}.trajetoria-item:hover{transform:translateY(-3px)}.trajetoria-item h3{font-size:1.5rem;font-weight:600;color:var(--color-primary);margin:0;font-family:Alumni Sans SC,sans-serif}.instituicao{font-size:1.1rem;color:var(--text-color-dark);opacity:.8;margin:0;font-family:Inter,sans-serif}.instituicao a{color:var(--color-primary);text-decoration:none;transition:all .3s ease}.instituicao a:hover{color:var(--color-secondary);text-decoration:underline}.periodo{font-size:.9rem;color:var(--color-secondary);margin:0;font-family:Inter,sans-serif}.descricao{margin:.5rem 0 0;padding-left:1.5rem;list-style-type:disc}.descricao li{font-size:1rem;line-height:1.5;color:var(--text-color-dark);opacity:.8;margin:.3rem 0;font-family:Inter,sans-serif}.habilidades-container{display:flex;gap:2rem}.habilidades-coluna{flex:1;display:flex;flex-direction:column;gap:1.5rem}.habilidade-categoria{padding:1.5rem;background:linear-gradient(145deg,#fff,#f8fafc);border-radius:15px;box-shadow:0 5px 15px #0000000d;border:1px solid #0e91a1;transition:transform .3s ease}.habilidade-categoria:hover{transform:translateY(-3px)}.habilidade-categoria h3{font-size:1.3rem;font-weight:600;color:var(--color-primary);margin:0 0 1rem;font-family:Alumni Sans SC,sans-serif;display:flex;align-items:center;gap:.8rem}.habilidade-icon{font-size:1.4rem;color:#0e91a1}.habilidade-categoria ul{list-style:none;padding:0;margin:0}.habilidade-categoria li{font-size:1rem;line-height:1.6;color:var(--text-color-dark);opacity:.9;margin:0;font-family:Inter,sans-serif;text-align:justify}@media (max-width: 768px){.trajetoria-container{padding:1rem}.trajetoria-content{gap:2rem}.trajetoria-section h2{font-size:2rem}.section-icon{font-size:1.8rem}.trajetoria-item{padding:1rem}.trajetoria-item h3{font-size:1.3rem}.instituicao{font-size:1rem}.habilidades-container{flex-direction:column;gap:1.5rem}.habilidade-categoria{padding:1.2rem}.habilidade-categoria h3{font-size:1.2rem}.habilidade-icon{font-size:1.3rem}.habilidade-categoria li{font-size:.95rem}}:root{--color-primary: #0e2233;--color-secondary: #8541a1;--color-accent-1: #4bbcb6;--color-accent-2: #eaeaea;--color-bg: #f7f8fa;--color-card-bg: #fff;--color-modal-bg: #f9f9fb;--color-title: #1a1a1a;--color-text: #333}.portfolio-container{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;padding:1rem;color:var(--text-color-dark);overflow-y:auto}.portfolio-carousel{width:100%;max-width:1200px;display:flex;align-items:center;gap:1rem;position:relative;overflow:hidden;padding:0 1rem}.carousel-button{background:none;border:none;color:var(--text-color-dark);font-size:1.5rem;cursor:pointer;padding:.5rem;transition:all .3s ease;opacity:.7;z-index:2;display:flex;align-items:center;justify-content:center}.carousel-button:hover{opacity:1;transform:scale(1.1);color:var(--color-primary)}.carousel-content{flex:1;display:flex;gap:2rem;align-items:center;transition:transform .5s cubic-bezier(.4,0,.2,1);will-change:transform}.carousel-content.sliding-left{animation:slideLeft .5s cubic-bezier(.4,0,.2,1)}.carousel-content.sliding-right{animation:slideRight .5s cubic-bezier(.4,0,.2,1)}.project-image{flex:1;max-width:600px;border-radius:20px;overflow:hidden;box-shadow:0 10px 30px #0000001a;transition:all .3s ease;background:#000;aspect-ratio:16/9;border:1px solid rgba(0,0,0,.1);padding:4px;background:linear-gradient(145deg,#fff,#f0f0f0)}.project-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease;display:block;border-radius:16px}.project-image:hover img{transform:scale(1.05)}.project-info{flex:1;display:flex;flex-direction:column;gap:1rem;padding:0 1rem}.project-info h2{font-size:2rem;font-weight:700;color:var(--text-color-dark);margin:0;font-family:Alumni Sans SC,sans-serif;text-transform:uppercase;letter-spacing:1px}.project-info p{font-size:1rem;line-height:1.5;color:var(--text-color-dark);opacity:.8;margin:0;font-family:Inter,sans-serif}.tech-stack{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:.5rem}.tech-icon{font-size:1.05rem;color:#0e91a1;opacity:.9}.tech-icon:hover{transform:translateY(-3px);color:var(--color-secondary)}.project-links{display:flex;gap:.8rem;margin-top:.5rem;flex-wrap:wrap}.project-link{display:flex;align-items:center;gap:.5rem;padding:.6rem 1rem;border-radius:8px;font-size:.9rem;font-weight:500;text-decoration:none;transition:all .3s ease;white-space:nowrap;background:#fff;color:var(--color-primary);border:2px solid var(--color-accent-2)}.project-link.github{background:transparent;color:#0e91a1;border:2px solid #0e91a1}.project-link.demo{background:transparent;color:#854178;border:2px solid #854178}.project-link:hover{box-shadow:0 5px 15px #00000014}.project-link.github:hover{background:#0e91a1;color:#fff;border-color:#0e91a1}.project-link.demo:hover{background:#854178;color:#fff;border-color:#854178}.carousel-dots{display:flex;gap:.6rem;margin-top:1rem;justify-content:center;padding:.5rem}.dot{width:10px;height:10px;border-radius:50%;background:#0003;border:none;cursor:pointer;transition:all .3s ease;padding:0;display:flex;align-items:center;justify-content:center}.dot.active{background:var(--color-primary);transform:scale(1.2)}@keyframes slideLeft{0%{opacity:0;transform:translate(50px)}to{opacity:1;transform:translate(0)}}@keyframes slideRight{0%{opacity:0;transform:translate(-50px)}to{opacity:1;transform:translate(0)}}@media (max-width: 1024px){.carousel-content{flex-direction:column;gap:1.5rem}.project-image{max-width:100%;width:100%}.project-info{text-align:center;width:100%;padding:0}.tech-stack,.project-links{justify-content:center}}@media (max-width: 768px){.portfolio-container{padding:.5rem}.portfolio-carousel{padding:0 .5rem}.carousel-button{font-size:1.2rem;padding:.3rem}.project-image{aspect-ratio:4/3;border-radius:15px;padding:3px}.project-image img{border-radius:12px}.project-info h2{font-size:1.5rem}.project-info p{font-size:.9rem}.tech-icon{font-size:1.2rem}.project-link{padding:.5rem .8rem;font-size:.8rem}.carousel-dots{gap:.4rem}.dot{width:8px;height:8px}}.portfolio-gallery-container{width:100%;max-width:1200px;margin:0 auto;padding:2.5rem 1rem 2rem;text-align:center;background:var(--color-bg)}.portfolio-title{font-size:2.5rem;font-weight:700;color:#0e91a1;margin:0 0 2.5rem;font-family:Alumni Sans SC,sans-serif;text-transform:uppercase;letter-spacing:1px;border-bottom:2px solid #0e91a1;padding-bottom:.5rem;display:flex;align-items:center;gap:1rem;justify-content:flex-start}.section-icon{font-size:2rem;color:#0e91a1}.portfolio-gallery{display:grid;grid-template-columns:repeat(auto-fit,minmax(270px,1fr));gap:2.5rem;width:100%}.portfolio-card{background:var(--color-card-bg);border-radius:18px;box-shadow:0 4px 24px #1e223312;cursor:pointer;overflow:hidden;transition:transform .18s cubic-bezier(.4,0,.2,1),box-shadow .18s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;align-items:stretch;border:1.5px solid var(--color-accent-2);position:relative;opacity:0;transform:translateY(40px) scale(.98);animation:cardFadeIn .7s cubic-bezier(.4,0,.2,1) forwards}.portfolio-card:nth-child(odd){animation-name:cardFadeInLeft}.portfolio-card:nth-child(2n){animation-name:cardFadeInRight}@keyframes cardFadeInLeft{0%{opacity:0;transform:translate(-40px) scale(.98)}to{opacity:1;transform:translate(0) scale(1)}}@keyframes cardFadeInRight{0%{opacity:0;transform:translate(40px) scale(.98)}to{opacity:1;transform:translate(0) scale(1)}}@keyframes cardFadeIn{0%{opacity:0;transform:translateY(40px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.portfolio-card:hover{transform:translateY(-8px) scale(1.035);box-shadow:0 12px 36px #1e223321;border-color:#0e91a1}.portfolio-card-image{width:100%;height:180px;object-fit:cover;background:var(--color-bg);border-bottom:1px solid var(--color-accent-2);transition:filter .2s;aspect-ratio:16/9}.portfolio-card-info{padding:1.3rem 1.1rem 1.1rem;flex:1;display:flex;flex-direction:column;align-items:flex-start;justify-content:space-between;animation:modalContentUp .6s cubic-bezier(.4,0,.2,1)}.portfolio-card-info h3{font-size:1.3rem;font-family:Alumni Sans SC,sans-serif;color:var(--color-primary);margin-bottom:.7rem;font-weight:700;letter-spacing:.5px;text-transform:uppercase;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:0 2px 4px rgba(0,0,0,.1);position:relative;padding-bottom:.3rem}.portfolio-card-info h3:after{content:"";position:absolute;bottom:0;left:0;width:30px;height:2px;background:linear-gradient(90deg,var(--color-primary),var(--color-secondary));border-radius:1px}.portfolio-card-techs{display:flex;gap:.6rem;flex-wrap:wrap;margin-top:.5rem;padding:.8rem 0;border-top:1px solid rgba(14,145,161,.1)}.tech-icon{font-size:1.2rem;color:#0e91a1;opacity:1;background:#0e91a11a;padding:.4rem;border-radius:8px;transition:all .3s ease;display:flex;align-items:center;justify-content:center;min-width:32px;height:32px}.tech-icon:hover{background:#0e91a133;transform:translateY(-2px) scale(1.1);color:var(--color-secondary);box-shadow:0 4px 12px #0e91a14d}.portfolio-card-links{display:flex;gap:.8rem;margin-top:1rem;flex-wrap:wrap;justify-content:center;width:100%}.portfolio-card-links .project-link{font-size:.85rem;padding:.5rem .8rem;border-radius:6px;flex:1;min-width:80px;max-width:120px;text-align:center;justify-content:center;background:var(--color-accent-2);color:var(--color-primary);text-decoration:none;font-weight:600;transition:all .3s ease;border:1.5px solid var(--color-accent-2)}.portfolio-card-links .project-link.github{color:#0e91a1;border-color:#0e91a1;background:transparent}.portfolio-card-links .project-link.demo{color:var(--color-secondary);border-color:var(--color-secondary);background:transparent}.portfolio-card-links .project-link:hover{background:#0e91a1;color:#fff;border-color:#0e91a1;transform:translateY(-2px);box-shadow:0 4px 12px #0e91a14d}.portfolio-card-links .project-link.demo:hover{background:var(--color-secondary);color:#fff;border-color:var(--color-secondary);box-shadow:0 4px 12px #8541a14d}.portfolio-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#1e223361;z-index:9999;display:flex;align-items:center;justify-content:center;animation:fadeIn .3s}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.portfolio-modal{background:var(--color-modal-bg);border-radius:20px;max-width:480px;width:95vw;max-height:90vh;overflow-y:auto;box-shadow:0 8px 40px #1e22332e;padding:2rem 1.5rem 1.5rem;position:relative;animation:modalPop .35s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;align-items:center;transform:scale(.92) translateY(30px);opacity:0;animation-fill-mode:forwards}@keyframes modalPop{0%{transform:scale(.92) translateY(30px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}.portfolio-modal-close{position:absolute;top:15px;right:20px;background:linear-gradient(135deg,#ff6b6b,#ee5a52);border:none;font-size:1.5rem;color:#fff;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);z-index:2;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:8px;box-shadow:0 4px 12px #ff6b6b4d;font-weight:700;line-height:1}.portfolio-modal-close:hover{background:linear-gradient(135deg,#ff5252,#d32f2f);transform:translateY(-2px) scale(1.05);box-shadow:0 6px 20px #ff6b6b66}.portfolio-modal-close:active{transform:translateY(0) scale(.95)}.portfolio-modal-image img{width:100%;max-height:220px;object-fit:cover;border-radius:12px;margin-bottom:1.2rem;background:var(--color-bg);aspect-ratio:16/9}.portfolio-modal-info{width:100%;text-align:left;animation:modalContentUp .6s cubic-bezier(.4,0,.2,1)}.portfolio-modal-info h2{font-size:1.5rem;color:var(--color-primary);margin-bottom:.7rem;font-family:Alumni Sans SC,sans-serif;font-weight:700;letter-spacing:.5px;text-transform:uppercase;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:0 2px 4px rgba(0,0,0,.1);text-align:center;padding-bottom:.5rem;border-bottom:2px solid rgba(14,145,161,.2)}.portfolio-modal-info p{font-size:1.08rem;color:var(--color-text);margin-bottom:1.1rem;font-family:Inter,Poppins,sans-serif}.portfolio-modal-techs{display:flex;gap:.8rem;margin-bottom:1.1rem;flex-wrap:wrap;justify-content:center;padding:1rem 0;background:#0e91a10d;border-radius:12px;border:1px solid rgba(14,145,161,.1);position:relative}.portfolio-modal-techs:before{content:"🛠️ Tecnologias utilizadas";position:absolute;top:-10px;left:50%;transform:translate(-50%);background:var(--color-modal-bg);padding:0 .5rem;font-size:.8rem;color:var(--color-secondary);font-weight:600;border-radius:4px}.portfolio-modal-links{display:flex;gap:1.2rem;margin-top:.5rem}.project-link{display:flex;align-items:center;gap:.4rem;font-size:1rem;color:var(--color-primary);text-decoration:none;font-weight:600;background:var(--color-accent-2);padding:.45rem 1.1rem;border-radius:8px;transition:background .2s,color .2s;border:1.5px solid var(--color-accent-2)}.project-link.github{color:#0e91a1}.project-link.demo{color:var(--color-secondary)}.project-link:hover{background:#0e91a1;color:#fff;border-color:#0e91a1}@media (max-width: 900px) and (min-width: 601px){.portfolio-gallery{grid-template-columns:1fr 1fr;gap:1.8rem;padding:0 .5rem}.portfolio-gallery-container{padding:2rem .5rem 2.5rem;max-width:98vw}.portfolio-card{border-radius:16px;min-width:0;box-shadow:0 4px 16px #1e22331a;max-width:100%}.portfolio-card-image{height:160px;border-radius:16px 16px 0 0;object-fit:cover}.portfolio-card-info{padding:1rem 1rem 1.2rem}.portfolio-card-info h3{font-size:1.1rem;margin-bottom:.7rem;line-height:1.3}.tech-icon{font-size:1rem;padding:.3rem;min-width:28px;height:28px}.portfolio-card-links{gap:.6rem;margin-top:.8rem;justify-content:center}.portfolio-card-links .project-link{font-size:.8rem;padding:.4rem .7rem;flex:1;min-width:70px;max-width:110px}.portfolio-title{font-size:2rem;margin-bottom:1.8rem;gap:.7rem;justify-content:center}.section-icon{font-size:1.5rem}.portfolio-modal{padding:1.5rem 1.2rem;max-width:90vw;border-radius:16px;margin:1rem}.portfolio-modal-image img{max-height:200px;border-radius:12px;margin-bottom:1rem;width:100%;object-fit:cover}.portfolio-modal-info h2{font-size:1.3rem;margin-bottom:.8rem;line-height:1.3}.portfolio-modal-info p{font-size:1rem;margin-bottom:1rem;line-height:1.5}.portfolio-modal-techs{gap:.5rem;margin-bottom:1rem;flex-wrap:wrap}.portfolio-modal-links{gap:1rem;margin-top:.5rem;flex-wrap:wrap;justify-content:center}.project-link{font-size:.95rem;padding:.6rem 1rem;border-radius:8px;min-width:80px;text-align:center;justify-content:center}.portfolio-modal-close{font-size:1.3rem;top:12px;right:15px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#ff6b6b,#ee5a52);border-radius:6px;box-shadow:0 3px 10px #ff6b6b4d;color:#fff}}@media (max-width: 600px){.portfolio-gallery{grid-template-columns:1fr;gap:1.5rem;padding:0 .5rem}.portfolio-gallery-container{padding:1.5rem .5rem 2rem;max-width:100vw}.portfolio-card{border-radius:16px;min-width:0;box-shadow:0 4px 20px #1e22331a;margin:0 auto;max-width:400px}.portfolio-card-image{height:200px;border-radius:16px 16px 0 0;object-fit:cover}.portfolio-card-info{padding:1rem 1.2rem 1.2rem}.portfolio-card-info h3{font-size:1.1rem;margin-bottom:.8rem;line-height:1.3}.tech-icon{font-size:1.1rem;padding:.3rem;min-width:28px;height:28px}.portfolio-card-links{gap:.5rem;margin-top:.7rem;justify-content:center}.portfolio-card-links .project-link{font-size:.75rem;padding:.35rem .6rem;flex:1;min-width:65px;max-width:100px}.portfolio-title{font-size:1.5rem;margin-bottom:1.5rem;gap:.6rem;padding-bottom:.4rem;justify-content:center}.section-icon{font-size:1.2rem}.portfolio-modal{padding:1.5rem 1.2rem;max-width:92vw;border-radius:16px;margin:1rem}.portfolio-modal-image img{max-height:180px;border-radius:12px;margin-bottom:1rem;width:100%;object-fit:cover}.portfolio-modal-info h2{font-size:1.2rem;margin-bottom:.8rem;line-height:1.3}.portfolio-modal-info p{font-size:.95rem;margin-bottom:1rem;line-height:1.5}.portfolio-modal-techs{gap:.5rem;margin-bottom:1rem;flex-wrap:wrap}.portfolio-modal-links{gap:.8rem;margin-top:.5rem;flex-wrap:wrap;justify-content:center}.project-link{font-size:.9rem;padding:.6rem 1rem;border-radius:8px;min-width:80px;text-align:center;justify-content:center}.portfolio-modal-close{font-size:1.5rem;top:10px;right:12px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#ffffffe6;border-radius:50%;box-shadow:0 2px 8px #0000001a}}@media (max-width: 480px){.portfolio-gallery{gap:1.2rem;padding:0 .3rem}.portfolio-gallery-container{padding:1.2rem .3rem 1.5rem}.portfolio-card{border-radius:14px;max-width:100%}.portfolio-card-image{height:180px;border-radius:14px 14px 0 0}.portfolio-card-info{padding:.8rem 1rem 1rem}.portfolio-card-info h3{font-size:1rem;margin-bottom:.6rem}.tech-icon{font-size:.95rem;padding:.25rem;min-width:24px;height:24px}.portfolio-card-links{gap:.4rem;margin-top:.6rem;justify-content:center}.portfolio-card-links .project-link{font-size:.7rem;padding:.3rem .5rem;flex:1;min-width:60px;max-width:90px}.portfolio-title{font-size:1.3rem;margin-bottom:1.2rem;gap:.5rem}.section-icon{font-size:1.1rem}.portfolio-modal{padding:1.2rem 1rem;max-width:95vw;border-radius:14px;margin:.5rem}.portfolio-modal-image img{max-height:160px;border-radius:10px;margin-bottom:.8rem}.portfolio-modal-info h2{font-size:1.1rem;margin-bottom:.6rem}.portfolio-modal-info p{font-size:.9rem;margin-bottom:.8rem}.portfolio-modal-techs{gap:.4rem;margin-bottom:.8rem}.portfolio-modal-links{gap:.6rem;margin-top:.4rem}.project-link{font-size:.85rem;padding:.5rem .8rem;border-radius:6px;min-width:70px}.portfolio-modal-close{font-size:1.1rem;top:10px;right:12px;width:26px;height:26px;background:linear-gradient(135deg,#ff6b6b,#ee5a52);border-radius:5px;box-shadow:0 2px 8px #ff6b6b4d;color:#fff}}@media (max-width: 360px){.portfolio-gallery{gap:1rem;padding:0 .2rem}.portfolio-gallery-container{padding:1rem .2rem 1.2rem}.portfolio-card{border-radius:12px}.portfolio-card-image{height:160px;border-radius:12px 12px 0 0}.portfolio-card-info{padding:.7rem .8rem .8rem}.portfolio-card-info h3{font-size:.95rem;margin-bottom:.5rem}.tech-icon{font-size:.9rem;padding:.2rem;min-width:22px;height:22px}.portfolio-card-links{gap:.3rem;margin-top:.5rem;justify-content:center}.portfolio-card-links .project-link{font-size:.65rem;padding:.25rem .4rem;flex:1;min-width:55px;max-width:80px}.portfolio-title{font-size:1.2rem;margin-bottom:1rem;gap:.4rem}.section-icon{font-size:1rem}.portfolio-modal{padding:1rem .8rem;max-width:98vw;border-radius:12px;margin:.3rem}.portfolio-modal-image img{max-height:140px;border-radius:8px;margin-bottom:.7rem}.portfolio-modal-info h2{font-size:1rem;margin-bottom:.5rem}.portfolio-modal-info p{font-size:.85rem;margin-bottom:.7rem}.portfolio-modal-techs{gap:.3rem;margin-bottom:.7rem}.portfolio-modal-links{gap:.5rem;margin-top:.3rem}.project-link{font-size:.8rem;padding:.4rem .7rem;border-radius:5px;min-width:60px}.portfolio-modal-close{font-size:1rem;top:8px;right:10px;width:24px;height:24px;background:linear-gradient(135deg,#ff6b6b,#ee5a52);border-radius:4px;box-shadow:0 2px 6px #ff6b6b4d;color:#fff}}.portfolio-card-info,.portfolio-card-techs,.portfolio-modal-techs{font-family:Inter,Poppins,sans-serif}.menu-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000b3;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);z-index:999;opacity:0;visibility:hidden;transition:opacity .5s ease,visibility .5s ease}.menu-overlay.active{opacity:1;visibility:visible}.menu-container{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:1000;opacity:0;visibility:hidden;transition:opacity .5s ease,visibility .5s ease;background-color:var(--background-color);border-radius:15px;box-shadow:0 10px 20px #0000001a;padding:2rem;max-width:300px;width:90%;border:1px solid rgba(0,0,0,.05)}.menu-container.active{opacity:1;visibility:visible}.menu-content{display:flex;flex-direction:column;align-items:center}.menu ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:1.5rem;width:100%}.menu li{width:100%}.menu button{width:100%;background:none;border:none;font-family:Inter,sans-serif;font-size:1.2rem;color:var(--text-color-dark);cursor:pointer;padding:.8rem 1rem;border-radius:8px;transition:background-color .3s ease,color .3s ease,transform .2s ease;display:flex;align-items:center;gap:1rem}.menu button:hover{background-color:var(--color-primary);color:var(--text-color-light);transform:translateY(-3px)}.menu button:active{transform:translateY(0)}.menu button svg{font-size:1.5rem;color:var(--color-primary);transition:color .3s ease}.menu button:hover svg{color:var(--text-color-light)}@media (max-width: 768px){.menu-container{padding:1.5rem;max-width:90%}.menu button{font-size:1rem;padding:.6rem .8rem;gap:.6rem}.menu button svg{font-size:1.3rem}}
