*,*:before,*:after{box-sizing:border-box}:root{--ff-primary: "Source Sans Pro", sans-serif;--ff-secondary: "Source Code Pro", monospace;--fw-reg: 300;--fw-bold: 900;--clr-light: #fff;--clr-dark: #303030;--clr-accent: #16e0bd;--fs-h1: 3rem;--fs-h2: 2.25rem;--fs-h3: 1.25rem;--fs-body: 1rem;--bs: .25em .25em .75em rgba(0, 0, 0, .25), .125em .125em .25em rgba(0, 0, 0, .15)}@media (min-width: 800px){:root{--fs-h1: 4.5rem;--fs-h2: 3.75rem;--fs-h3: 1.5rem;--fs-body: 1.125rem}}html{scroll-behavior:smooth}body{background:var(--clr-light);color:var(--clr-dark);margin:0;font-family:var(--ff-primary);font-size:var(--fs-body);line-height:1.6}section{padding:5em 2em}img{display:block;max-width:100%}strong{font-weight:var(--fw-bold)}:focus{outline:3px solid var(--clr-accent);outline-offset:3px}.btn{display:inline-block;padding:.5em 2.5em;background:var(--clr-accent);color:var(--clr-dark);text-decoration:none;cursor:pointer;font-size:.8rem;text-transform:uppercase;letter-spacing:2px;font-weight:var(--fw-bold);transition:transform .2s ease-in-out}.btn:hover{transform:scale(1.1)}h1,h2,h3{line-height:1;margin:0}h1{font-size:var(--fs-h1)}h2{font-size:var(--fs-h2)}h3{font-size:var(--fs-h3)}.section__title{margin-bottom:.25em}.section__title--intro{font-weight:var(--fw-reg)}.section__title--intro strong{display:block}.section__subtitle{margin:0;font-size:var(--fs-h3)}.section__subtitle--intro,.section__subtitle--about{background:var(--clr-accent);padding:.25em 1em;font-family:var(--ff-primary);margin-bottom:1em}.section__subtitle--work{color:var(--clr-accent);font-weight:var(--fw-bold);margin-bottom:2em}header{display:flex;justify-content:space-between;padding:1em}.logo{max-width:100px}.nav{position:fixed;background:var(--clr-dark);color:var(--clr-light);top:0;bottom:0;left:0;right:0;z-index:100;transform:translate(100%);transition:transform .25s cubic-bezier(.5,0,.5,1)}.nav__list{list-style:none;display:flex;height:100%;flex-direction:column;justify-content:space-evenly;align-items:center;margin:0;padding:0}.nav__link{color:inherit;font-weight:var(--fw-bold);font-size:var(--fs-h2);text-decoration:none}.nav__link:hover{color:var(--clr-accent)}.nav-toggle{padding:.5em;background:transparent;border:0;cursor:pointer;position:relative;z-index:1000}.nav-open .nav{transform:translate(0)}.nav-open .nav-toggle{position:fixed}.nav-open .hamburger{transform:rotate(.625turn)}.nav-open .hamburger:before{transform:rotate(90deg) translate(-6px)}.nav-open .hamburger:after{opacity:0}.hamburger{display:block;position:relative}.hamburger,.hamburger:before,.hamburger:after{background:var(--clr-accent);width:2em;height:3px;border-radius:1em;transition:transform .25s ease-in-out}.hamburger:before,.hamburger:after{content:"";position:absolute;left:0;right:0}.hamburger:before{top:6px}.hamburger:after{bottom:6px}.intro{position:relative}.intro__img{box-shadow:var(--bs)}.section__subtitle--intro{display:inline-block}@media (min-width: 600px){.intro{display:grid;width:min-content;margin:0 auto;grid-column-gap:1em;grid-template-areas:"img title" "img subtitle";grid-template-columns:min-content max-content}.intro__img{grid-area:img;min-width:250px;position:relative;z-index:2}.section__subtitle--intro{align-self:start;grid-column:-1 / 1;grid-row:2;text-align:right;position:relative;left:-1.5em;width:calc(100% + 1.5em)}}@media (min-width: 360px){.portfolio{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1em}.portfolio__item{background:var(--clr-accent);overflow:hidden}.portfolio__img{width:100%;height:100%;object-fit:cover;transition:transform .75s cubic-bezier(.5,0,.5,1)}}.my-services{background-color:var(--clr-dark);background-image:url(../images/services-bg.jpg);background-size:cover;color:var(--clr-light);text-align:center}.section__title--services{color:var(--clr-accent);position:relative}.section__title--services:after{content:"";display:block;width:2em;height:1px;margin:.5em auto 1em;background:var(--clr-light);opacity:.25}.services{margin-bottom:4em}.service{max-width:500px;margin:0 auto}@media (min-width: 800px){.services{display:flex;max-width:1000px;margin-left:auto;margin-right:auto}.service+.service{margin-left:2em}}.about-me{max-width:1000px;margin:0 auto}.about-me__img{box-shadow:var(--bs)}@media (min-width: 600px){.about-me{display:grid;grid-template-columns:1fr 200px;grid-template-areas:"title img" "subtitle img" "text img";grid-column-gap:2em}.section__title--about{grid-area:title}.section__subtitle--about{grid-column:1 / -1;grid-row:2;position:relative;left:-1em;width:calc(100% + 2em);padding-left:1em;padding-right:calc(200px + 4em)}.about-me__img{grid-area:img;position:relative;z-index:2}}.my-work{background-color:var(--clr-dark);color:var(--clr-light);text-align:center;padding:4em 0}.portfolio{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1em;max-width:100%;padding:0 1em}.portfolio__item{position:relative;display:block;width:100%;padding-bottom:100%;overflow:hidden;background:var(--clr-accent)}.portfolio__img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;transition:transform .75s cubic-bezier(.5,0,.5,1)}@media (max-width: 600px){.portfolio{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.5em;padding:0 .5em}}@media (max-width: 360px){.portfolio{grid-template-columns:1fr}}.portfolio__item{background:var(--clr-accent);overflow:hidden}.portfolio__img{transition:transform .75s cubic-bezier(.5,0,.5,1),opacity .25s linear}.portfolio__item:focus{position:relative;z-index:2}.portfolio__img:hover,.portfolio__item:focus .portfolio__img{transform:scale(1.2);opacity:.5;cursor:pointer}.modal{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.8);display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background:white;padding:20px;border-radius:8px;max-width:500px;width:90%;box-shadow:0 4px 8px #0003;text-align:center;position:relative}.close-button{position:absolute;top:10px;right:10px;font-size:24px;cursor:pointer;border:none;background:transparent;color:#ff5a5f;transition:transform .2s,color .2s}.close-button:hover{transform:scale(1.2);color:red}.modal-content img{width:100%;height:auto;border-radius:8px;margin-top:10px}.modal-content h2{margin-bottom:.5em;color:#000}.modal-content p{margin-bottom:1em;color:#000}@media (max-width: 360px){.modal-content{width:95%;margin:10px;padding:1em}.modal-header img{max-width:100%;height:auto}.project-info,.project-components,.project-result{padding:.5em}}.footer{background:#111;color:var(--clr-accent);text-align:center;padding:2.5em 0;font-size:var(--fs-h3)}.footer a{color:inherit;text-decoration:none}.footer__link{font-weight:var(--fw-bold)}.footer__link:hover,.social-list__link:hover{opacity:.7}.footer__link:hover{text-decoration:underline}.social-list{list-style:none;display:flex;justify-content:center;margin:2em 0 0;padding:0}.social-list__item{margin:0 .5em}.social-list__link{padding:.5em}.header-controls{display:flex;align-items:center;gap:1em;position:absolute;right:1em;top:1em}.language-switch{position:static;padding:.5em 1em;background:var(--clr-dark);color:var(--clr-accent);border:2px solid var(--clr-accent);border-radius:4px;cursor:pointer;font-size:var(--fs-body);font-weight:var(--fw-bold);transition:all .2s ease-in-out}.language-switch:hover{background:var(--clr-accent);color:var(--clr-dark);opacity:1}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.85);display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background:var(--clr-light);padding:2em;border-radius:8px;max-width:800px;max-height:90vh;overflow-y:auto;position:relative}.modal-close{position:absolute;right:1em;top:1em;background:none;border:none;font-size:1.5em;cursor:pointer}.modal-header{margin-bottom:2em;text-align:center}.modal-header img{max-width:100%;height:auto;margin:1em 0}.project-info{margin-bottom:2em;padding:1em;background:var(--clr-dark);border-radius:4px}.project-components .component{margin-bottom:1em;padding-bottom:1em;border-bottom:1px solid var(--clr-dark);color:#000}.project-components h3{color:#000}.project-result{margin-top:2em;padding:1em;background:var(--clr-accent);color:var(--clr-dark);border-radius:4px}.project-description{color:#000}.project-info p{color:var(--clr-light)}.image-gallery{position:relative;width:100%;margin:1em 0}.image-gallery img{width:100%;height:auto;object-fit:cover}.gallery-nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(0,0,0,.5);color:#fff;border:none;padding:1em .5em;cursor:pointer;font-size:1.5em}.gallery-nav.prev{left:0}.gallery-nav.next{right:0}.gallery-nav:hover{background:rgba(0,0,0,.8)}.image-container{position:relative;overflow:hidden}.image-link{display:block}.image-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.7);display:flex;flex-direction:column;align-items:center;justify-content:center;opacity:0;transition:all .3s ease;color:#fff;text-decoration:none;cursor:pointer}.image-link:hover .image-overlay{opacity:1}.image-overlay i{font-size:2em;margin-bottom:.5em;animation:pulse 2s infinite}.image-overlay span{font-size:1.2em;background:var(--clr-accent);padding:.5em 1em;border-radius:4px;transform:translateY(20px);transition:transform .3s ease}.image-link:hover .image-overlay span{transform:translateY(0)}.image-container:after{content:"Click para visitar →";position:absolute;bottom:48%;right:38%;background:var(--clr-accent);color:var(--clr-dark);padding:.5em 1em;border-radius:4px;font-size:.8em;opacity:.8;animation:hide 2s infinite}.image-container:hover:after{animation:none;opacity:0}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}@keyframes hide{0%{opacity:1}50%{scale:1.1}to{opacity:0}}
