*,*:before,*:after{box-sizing:border-box}body,h1,h2,h3,h4,p,figure,blockquote,dl,dd{margin:0}h1{font-size:2rem}h2{font-size:1.5rem}h3{font-size:1.25rem}h4{font-size:1.125}h5,p{font-size:1rem}html,body{height:100%}body{min-height:100dvh;text-rendering:optimizeSpeed;line-height:1.5;font-family:Inter,sans-serif;background-color:#111827;color:#e5e7eb}#root{display:flex;flex-direction:column;min-height:100dvh}.app-layout{display:flex;flex-direction:column;min-height:100dvh;width:100%}.app-content{flex:1 0 auto;display:flex;flex-direction:column;width:100%;padding-bottom:env(safe-area-inset-bottom)}footer{flex-shrink:0}h1,h2,h3{font-weight:600;line-height:1.2}p{margin-bottom:1rem}@font-face{font-family:Inter;src:url(/assets/Inter-Regular-COLGFB3M.woff2) format("woff2");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Inter;src:url(/assets/Inter-Italic-Bm_w1qmz.woff2) format("woff2");font-weight:400;font-style:italic;font-display:swap}@font-face{font-family:Inter;src:url(/assets/Inter-SemiBold-BAEEcJ4E.woff2) format("woff2");font-weight:600;font-style:normal;font-display:swap}@font-face{font-family:Inter;src:url(/assets/Inter-Bold-BOs3KVhN.woff2) format("woff2");font-weight:700;font-style:normal;font-display:swap}.site-header{width:100%;background:#1f2937;border-bottom:3px solid rgba(129,140,248,.1);position:relative;z-index:10;overflow:hidden;box-sizing:border-box}.site-header__container{max-width:1200px;margin:0 auto;padding:1.5rem;display:flex;flex-direction:row;align-items:center;justify-content:center;gap:1.5rem}@media(min-width:768px){.site-header__container{justify-content:center;height:120px;padding:0 1.5rem}}.site-header__brand{display:flex;align-items:center;transition:transform .3s ease}.site-header__logo{width:100px;height:auto;object-fit:contain}@media(min-width:768px){.site-header__logo{width:160px;padding-top:.85em}}.site-header__content{text-align:center}@media(min-width:768px){.site-header__content{position:absolute;left:50%;transform:translate(-50%)}}.site-header__title{font-size:24px;font-weight:500;text-transform:uppercase;letter-spacing:.2em;color:#51dcf2;text-shadow:0 0 10px rgba(34,211,238,.3)}.hero-wrapper{width:100%;max-width:1400px;margin:0 auto}@media(min-width:768px){.hero-wrapper{margin-top:2rem}}.hero{position:relative;width:100%;height:260px;max-height:420px;overflow:hidden;background-color:#111827}@media(min-width:768px){.hero{height:340px}}@media(min-width:1200px){.hero{height:420px}}.hero__track{display:flex;height:100%;will-change:transform}.hero__slide{position:relative;min-width:100%;height:100%;display:flex;align-items:center;background-color:#111827}.hero__slide:after{content:"";position:absolute;inset:0;background:linear-gradient(to bottom,#11182733,#111827b3);z-index:1}.hero__image{display:block;width:100%;height:100%;object-fit:cover}.hero__content{position:absolute;width:85%;z-index:2;max-width:40rem;padding:.5rem;color:#fff;top:50%;left:5%;transform:translateY(-50%)}@media(min-width:768px){.hero__content{left:10%;top:50%;width:auto}}.hero__title{font-size:1.5rem;line-height:1.2;margin:.5rem 0}@media(min-width:768px){.hero__title{font-size:3rem;margin:1rem 0}}.hero__subtitle{font-size:.95rem}@media(min-width:768px){.hero__subtitle{font-size:1.125rem}}.hero__btn{position:absolute;z-index:3;top:50%;transform:translateY(-50%);background:#0006;border:none;color:#fff;width:45px;height:45px;display:none;align-items:center;justify-content:center;cursor:pointer;border-radius:.5rem;transition:background .3s}@media(min-width:768px){.hero__btn{display:flex}}.hero__btn:hover{background:#000000b3}.hero__btn--prev{left:20px}.hero__btn--next{right:20px}.hero__controls{display:flex;align-items:center;justify-content:center;gap:12px;padding:.5rem 0;background:transparent}@media(min-width:768px){.hero__controls{padding:1rem 0}}.hero__dots{display:flex;align-items:center;gap:10px;padding:8px 15px;background:#6366f1;border-radius:20px;flex:0 0 auto}.hero__dot{width:12px;height:12px;flex:0 0 12px;border-radius:50%;border:none;cursor:pointer;background:#ffffff4d;transition:all .3s ease;padding:0}.hero__dot--active{background:#22d3ee;box-shadow:0 0 0 4px #22d3ee4d}.hero__toggle-btn{background:#6366f1;color:#fff;border:none;width:26px;height:26px;flex:0 0 26px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.8rem;transition:transform .2s;padding:0}.button{display:inline-block;padding:.75rem 1.5rem;border-radius:.5rem;font-weight:600;cursor:pointer;border:none;transition:all .2s ease}.button--primary{background-color:#6366f1;color:#fff}.button--primary:hover{background-color:#3e41ee}.button--primary:focus-visible{outline:2px solid #22D3EE;outline-offset:3px}.profile-cards{max-width:1200px;width:100%;margin:0 auto;padding:3rem 1.5rem 0rem;scroll-margin-top:0;display:flex;flex-direction:column;gap:2rem;content-visibility:auto;contain-intrinsic-size:0 850px}@media(min-width:768px){.profile-cards{contain-intrinsic-size:0 700px}}@media(min-width:1200px){.profile-cards{contain-intrinsic-size:0 450px}}.profile-cards__grid{display:grid;gap:1rem;grid-template-columns:repeat(1,1fr);align-items:start}@media(min-width:768px){.profile-cards__grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1200px){.profile-cards__grid{grid-template-columns:repeat(4,1fr)}}.profile-cards__content{margin-top:2rem;width:100%;height:auto;padding-bottom:4rem}.profile-card{color:#000;padding:1.5rem;border:1px solid white;background-color:#fff;cursor:pointer;font-size:1.1rem;border-radius:8px;transition:background-color .2s,opacity .2s;box-sizing:border-box;display:flex;align-items:center;justify-content:center;min-height:80px;text-align:center}.profile-card:hover{background:#818cf8;color:#fff;border:1px solid #6366F1}.profile-card.active{background:#6366f1;color:#fff;border:1px solid #6366F1;transform:none}.profile-cards__content .about,.profile-cards__content .experience,.profile-cards__content .education,.profile-cards__content .projects{background-color:#1f2937;border-radius:8px;color:#fff;display:block;height:auto;min-height:min-content;margin:0 auto;padding:2.5rem}.profile-cards__content .about h1,.profile-cards__content .about h2,.profile-cards__content .experience h1,.profile-cards__content .experience h2,.profile-cards__content .education h1,.profile-cards__content .education h2,.profile-cards__content .projects h1,.profile-cards__content .projects h2{margin-bottom:1.5rem}.profile-cards__content .about h3,.profile-cards__content .experience h3,.profile-cards__content .education h3,.profile-cards__content .projects h3{border-bottom:1.6px solid #818CF8;padding-bottom:.5rem;margin:1.5rem 0}.about{padding:2rem 1rem;width:100%;box-sizing:border-box}.about__header{display:flex;flex-direction:column;gap:1.5rem}@media(min-width:768px){.about__header{flex-direction:row-reverse;align-items:flex-start;gap:3rem}}.about__main-content{flex:1;width:100%}.about__info{display:flex;flex-direction:column}.about__image{width:250px;height:350px;object-fit:cover;border-radius:12px;flex-shrink:0;align-self:center;order:2}@media(min-width:768px){.about__image{order:2;align-self:flex-start}}.about__main-content{order:1}.about__main-content h2{margin-top:0}.about__main-content h3{border-bottom:1px solid rgba(255,255,255,.2);padding-bottom:.5rem;margin:1.5rem 0 .8rem}@media(min-width:768px){.about__main-content{order:1}}.about__skills-container,.about__aditional-information,.about__contact{order:3}.about__skills{display:flex;flex-wrap:wrap;gap:8px;list-style:none;padding:0;margin:0;justify-content:flex-start}.about__skills li{background:#4b5563;padding:5px 12px;border-radius:4px;font-size:.85rem}.about__aditional-information .aditional-information ul li::marker{color:#6366f1;font-size:1.1rem}.about__contact .contact{display:flex;flex-direction:column;gap:1rem;margin-top:1rem}@media(min-width:768px){.about__contact .contact{flex-direction:row;flex-wrap:wrap;gap:2rem}}.about__contact .contact .phone-contact,.about__contact .contact .email-contact{display:flex;align-items:center;gap:.2rem}.about__contact .contact .phone-contact p,.about__contact .contact .email-contact p{margin:0;line-height:1;word-break:break-all;padding:8px}.about__contact .contact .phone-contact svg,.about__contact .contact .email-contact svg{color:#6366f1;font-size:1.1rem;flex-shrink:0}.experience{margin-top:1rem;padding-left:1rem;padding-right:1rem;position:relative;box-sizing:border-box}.experience h2{margin-bottom:2rem}.experience__item{position:relative;margin-bottom:4rem}.experience__item h3{margin-bottom:.3rem;color:#fff}.experience__company{font-weight:600;color:#22d3ee;margin-bottom:.2rem;display:block}.experience__dates{font-size:.85rem;opacity:.7;font-style:italic;display:block;margin-bottom:1rem;text-transform:capitalize}.experience__main-responsibilities{margin-bottom:1.5rem;line-height:1.6;color:#ffffffe6;word-wrap:break-word}.experience__projects-title{font-weight:700;text-transform:uppercase;letter-spacing:1px;padding-bottom:.5rem}.experience__projects{display:grid;gap:1rem;margin-top:1.5rem}.experience__project{background:#323c4d66;padding:1.2rem;border-radius:12px;border-left:4px solid rgba(34,211,238,.5);box-sizing:border-box;contain:layout;scroll-margin-top:100px}.experience__project:hover{background:#323c4d99}.experience__project-toggle{width:100%;background:none;border:none;font-weight:700;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:10px;text-align:left;color:#fff;font-size:1.05rem;padding:0}.experience__project-toggle:hover{color:#22d3ee}.experience__project-toggle span{word-wrap:break-word;overflow-wrap:break-word}.experience__project-content{max-height:0;overflow:hidden;opacity:0;transform:translateY(-8px);visibility:hidden;transition:max-height .4s cubic-bezier(.4,0,.2,1),opacity .3s ease,transform .3s ease,visibility .4s}.experience__project-content.open{max-height:2000px;opacity:1;transform:translateY(0);margin-top:1.2rem;padding-top:1rem;border-top:1px dashed rgba(34,211,238,.2);overflow-y:visible;visibility:visible}.experience__project-description{line-height:1.6;color:#fffc;margin-bottom:1.2rem;font-style:italic;word-wrap:break-word;overflow-wrap:break-word}.experience__project-client{font-weight:700;text-transform:uppercase;color:#22d3ee;letter-spacing:.8px;margin-bottom:1rem;word-wrap:break-word}.experience__project-role{font-weight:600;color:#fff;display:inline-block;border-left:3px dotted rgba(34,211,238,.2);padding-left:.5em;margin-bottom:1rem}.experience__project-responsibilities{line-height:1.5;color:#ffffffbf;background:#1f2937;padding:1.2rem;border-radius:8px;word-wrap:break-word;overflow-wrap:break-word;-webkit-hyphens:auto;hyphens:auto}.experience__project-responsibilities p{margin:0;white-space:normal}.experience__arrow{transition:transform .25s ease;color:#22d3ee;flex-shrink:0}.experience__arrow.open{transform:rotate(180deg)}.education{margin-top:3rem}.education__list{display:grid;gap:1.5rem}.education__group{background:#323c4d;border-radius:10px;padding:1rem;border-left:3px solid rgba(34,211,238,.3);transition:border-color .3s ease}.education__group.is-open{border-left-color:#22d3ee}.education__group button:hover{color:#22d3ee}.education__toggle{width:100%;background:none;border:none;color:inherit;font-size:1.1rem;font-weight:600;cursor:pointer;display:flex;justify-content:space-between;align-items:center;text-align:left;padding:0}.education__arrow{transition:transform .25s ease;color:#22d3ee}.education__arrow.open{transform:rotate(180deg)}.education__content{max-height:0;overflow:hidden;opacity:0;transform:translateY(-5px);transition:max-height .4s ease,opacity .25s ease,transform .25s ease;padding-left:.5rem}.education__content.open{max-height:2000px;opacity:1;transform:translateY(0);margin-top:1rem}.education__item{margin-bottom:2rem;position:relative}.education__item:last-child{margin-bottom:.5rem}.education__title{font-size:1.1rem;font-weight:600;color:#22d3ee;margin-bottom:.3rem}.education__institution{display:block;font-weight:500;margin-bottom:.4rem;opacity:.9}.education__info-row{display:flex;align-items:center;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}.education__dates{font-size:.85rem;opacity:.7;margin:0}.education__hours{font-size:.7rem;padding:2px 8px;border-radius:4px;text-transform:uppercase;background:#22d3ee26;color:#22d3ee;font-weight:600;border:1px solid rgba(34,211,238,.2)}.education__images{display:flex;flex-wrap:wrap;gap:.8rem;margin-bottom:1rem}.education__images img{width:130px;height:90px;object-fit:contain;background:#0003;border-radius:6px;cursor:pointer;border:1px solid rgba(34,211,238,.1);transition:transform .25s ease,border-color .25s ease}.education__images img:hover{border-color:#22d3ee}.education__documents{display:flex;flex-wrap:wrap;gap:.8rem;margin-bottom:1em}.education__documents a{font-size:.85rem;color:#fff;text-decoration:none;display:inline-flex;align-items:center;gap:.5rem;padding:6px 12px;background:#ffffff0d;border-radius:6px;border:1px solid rgba(255,255,255,.1);transition:all .25s ease}.education__documents a:before{font-size:.8rem}.education__documents a:hover{background:#22d3ee33;border-color:#22d3ee;color:#22d3ee}.projects{margin-top:3rem}.projects__list{display:grid;gap:1.5rem}.projects__item{background:#323c4d;border-radius:10px;padding:1rem;border-left:3px solid rgba(34,211,238,.3)}.projects__item button:hover{color:#22d3ee}.projects__toggle{width:100%;background:none;border:none;color:inherit;font-size:1.1rem;font-weight:600;cursor:pointer;display:flex;justify-content:space-between;align-items:center;text-align:left}.projects__arrow{transition:transform .25s ease;color:#22d3ee}.projects__arrow.open{transform:rotate(180deg)}.projects__status{margin-left:.6rem;font-size:.7rem;padding:2px 6px;border-radius:4px;text-transform:uppercase}.projects__status--completed{background:#50c87833;color:#50c878}.projects__status--in-progress{background:#22d3ee33;color:#22d3ee}.projects__content{max-height:0;overflow:hidden;opacity:0;transform:translateY(-5px);transition:max-height .4s ease,opacity .25s ease,transform .25s ease;padding-left:.5rem}.projects__content.open{max-height:2000px;opacity:1;transform:translateY(0);margin-top:1rem}.projects__image{width:100%;max-height:220px;object-fit:cover;border-radius:8px;margin-bottom:1rem;cursor:pointer;transition:transform .2s ease}.projects__description{font-size:.95rem;margin-bottom:1rem;line-height:1.5}.projects__technologies{display:flex;flex-wrap:wrap;gap:.4rem;list-style:none;padding:0;margin-bottom:1rem}.projects__technologies li{background:#4b5563;padding:4px 10px;border-radius:4px;font-size:.8rem}.projects__links{display:flex;gap:1rem;flex-wrap:wrap}.projects__links a{font-size:.9rem;color:#22d3ee;text-decoration:none}.projects__links a:hover{color:#22d3ee66}.breadcrumb__content{max-width:1200px;padding:1rem 1.5rem}.breadcrumb{font-size:.85rem;display:flex;align-items:center;gap:.4rem;color:#22d3ee}.breadcrumb__link{color:#22d3ee;text-decoration:none;transition:color .2s}.breadcrumb__link:hover{color:#fff;text-decoration:underline}.breadcrumb__separator{opacity:.6}.breadcrumb__current{color:#fff;font-weight:500}.legal-page{max-width:1200px;width:calc(100% - 2rem);background-color:#1f2937;border-radius:8px;color:#fff;display:block;height:auto;min-height:min-content;margin:0 auto 3rem;padding:3rem 1.5rem}@media(min-width:768px){.legal-page{padding:4rem 3rem}}@media(min-width:1200px){.legal-page{width:100%;margin:0 auto}}.legal-page h1{margin-bottom:1.5rem}.site-footer{border-top:3px solid rgba(129,140,248,.1);background:#1f2937;padding:2rem 0;overflow:hidden;box-sizing:border-box}.site-footer .footer-icon{width:1.5rem;height:1.5rem;fill:currentColor;display:block}.site-footer__container{max-width:1200px;margin:0 auto;padding:0 1.5rem;display:flex;flex-direction:column;gap:1rem}.site-footer__top{display:flex;flex-direction:column;align-items:flex-start;gap:.8rem}.site-footer__social{display:flex;align-items:center;gap:1.2rem}.site-footer__social a{display:flex;align-items:center;font-size:1.5rem;color:#22d3ee;text-decoration:none;transition:all .2s}.site-footer__social a:hover{color:#fff}.site-footer__legal{display:flex;flex-wrap:wrap;gap:.8rem;font-size:.9rem}.site-footer__legal a{font-size:.9rem;color:#22d3ee;text-decoration:none}.site-footer__legal a:hover{color:#fff;text-decoration:underline}.site-footer__legal span{display:none}.site-footer__bottom{font-size:.85rem;color:#22d3ee;text-align:left}.footer-divider{opacity:.4;color:#22d3ee}@media(min-width:768px){.site-footer__top{flex-direction:row;justify-content:space-between;align-items:center}.site-footer__bottom{text-align:right}.site-footer__legal span{display:block;color:#22d3ee}}.cookie-banner{min-height:10rem;width:100%;position:fixed;bottom:-100%;left:0;background-color:#111827d9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);color:#e5e7eb;border-top:1px solid rgba(99,102,241,.3);box-shadow:0 -10px 30px #00000080;padding:1.5rem 2rem;display:flex;flex-direction:column;gap:1.5rem;align-items:center;justify-content:center;transition:all .6s cubic-bezier(.16,1,.3,1);opacity:0;z-index:9999}.cookie-banner--visible{bottom:0;opacity:1}.cookie-banner p{margin:0;text-align:center;line-height:1.6;font-size:.95rem;max-width:800px}.cookie-banner p .cookie-banner__link{color:#6366f1;text-decoration:none;font-weight:600;border-bottom:1px dashed #6366F1;transition:all .2s ease}.cookie-banner p .cookie-banner__link:hover{color:#818cf8;border-bottom-style:solid}.cookie-banner__actions{display:flex;gap:1rem;flex-shrink:0}.cookie-banner__btn{padding:.6rem 1.2rem;border-radius:4px;border:1px solid transparent;cursor:pointer;font-weight:600;font-size:.85rem;text-transform:uppercase;letter-spacing:.5px;transition:all .3s ease}.cookie-banner__btn--accept{background-color:#6366f1;color:#fff;box-shadow:0 4px 14px #6366f166}.cookie-banner__btn--accept:hover{background-color:transparent;border-color:#6366f1;color:#6366f1}.cookie-banner__btn--decline{background-color:transparent;border:1px solid rgba(229,231,235,.3);color:#e5e7eb}.cookie-banner__btn--decline:hover{background-color:#e5e7eb1a;border-color:#e5e7eb}@media(min-width:768px){.cookie-banner{flex-direction:row;justify-content:space-between;padding:1.5rem 5%}.cookie-banner p{text-align:left}}.cookie-banner__mini{position:fixed;bottom:1.5rem;left:1.5rem;background-color:#111827cc;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);color:#6366f1;border:1px solid rgba(99,102,241,.5);border-radius:12px;width:44px;height:44px;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:9998;transition:all .3s ease}.cookie-banner__mini:hover{transform:scale(1.1) rotate(10deg);background-color:#6366f1;color:#fff;box-shadow:0 0 15px #6366f1}.image-modal{position:fixed;inset:0;z-index:10000;display:flex;align-items:center;justify-content:center;padding:1rem;background:#000000a6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);overflow-y:auto}.image-modal__content{position:relative;width:fit-content;max-width:min(95vw,1400px);max-height:95vh;display:flex;align-items:center;justify-content:center}.image-modal img{display:block;width:auto;height:auto;max-width:100%;max-height:90vh;object-fit:contain;border-radius:12px;box-shadow:0 10px 40px #00000059}@media(min-width:768px){.image-modal img{border-radius:16px}}.image-modal__close{position:absolute;top:-2em;right:-2em;width:42px;height:42px;border:none;border-radius:50%;background:#00000073;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#fff;font-size:1.2rem;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s ease}.image-modal__close:hover{background:#000000b3}@media(min-width:768px){.image-modal__close{top:-2em;right:-2em;width:48px;height:48px;font-size:1.4rem}}.image-modal__navigation{position:absolute;inset:0;pointer-events:none}.image-modal__prev,.image-modal__next{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;border:none;border-radius:50%;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#fff;font-size:2rem;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer;pointer-events:auto;transition:background .2s ease}.image-modal__prev:hover,.image-modal__next:hover{background:#000000b3}@media(min-width:768px){.image-modal__prev,.image-modal__next{width:56px;height:56px;font-size:2.4rem}}.image-modal__prev{left:12px}.image-modal__next{right:12px}.scroll-to-top{position:fixed;bottom:1.5rem;right:1.5rem;background-color:#111827cc;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);color:#6366f1;border:1px solid rgba(99,102,241,.5);border-radius:12px;width:44px;height:44px;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:9998;transition:all .3s ease}.scroll-to-top:hover{transform:scale(1.1) rotate(10deg);background-color:#6366f1;color:#fff;box-shadow:0 0 15px #6366f1}@media(min-width:1200px){.scroll-to-top{right:2.5rem}}
