@charset "UTF-8";@import"https://fonts.googleapis.com/css2?family=Poppins:wght@400;500;600&display=swap";:root{--header-height: 3.5rem;--first-hue: 347;--sat: 78%;--lig: 52%;--second-hue: 219;--first-color: hsl(var(--first-hue), var(--sat), var(--lig));--first-color-alt: hsl(var(--first-hue), var(--sat), 48%);--title-color: hsl(var(--second-hue), 15%, 95%);--text-color: hsl(var(--second-hue), 8%, 75%);--text-color-light: hsl(var(--second-hue), 4%, 55%);--body-color: hsl(var(--second-hue), 48%, 8%);--container-color: hsl(var(--second-hue), 32%, 12%);--body-font: "Poppins", sans-serif;--biggest-font-size: 1.75rem;--h1-font-size: 1.5rem;--h2-font-size: 1.25rem;--h3-font-size: 1rem;--normal-font-size: .938rem;--small-font-size: .813rem;--smaller-font-size: .75rem;--tiny-font-size: .625rem;--font-medium: 500;--font-semibold: 600;--z-tooltip: 10;--z-fixed: 100;--z-modal: 1000}@media screen and (min-width: 968px){:root{--biggest-font-size: 2.5rem;--h1-font-size: 2.25rem;--h2-font-size: 1.5rem;--h3-font-size: 1.25rem;--normal-font-size: 1rem;--small-font-size: .875rem;--smaller-font-size: .813rem}}*,*:before,*:after{box-sizing:border-box;padding:0;margin:0}html{scroll-behavior:smooth}body,button,input,textarea{font-family:var(--body-font);font-size:var(--normal-font-size)}body{background-color:var(--body-color);color:var(--text-color);transition:background-color .4s,color .4s}h1,h2,h3{color:var(--title-color);font-weight:var(--font-semibold)}ul{list-style:none}a{text-decoration:none}button{cursor:pointer;border:none;outline:none;background:transparent}img{max-width:100%;height:auto}.change-theme{font-size:1.25rem;cursor:pointer;transition:color .3s;background:transparent!important;border:none!important;outline:none!important;box-shadow:none!important;padding:0;color:var(--title-color);display:flex;align-items:center;justify-content:center}.change-theme:hover{color:var(--first-color)}.change-theme{-webkit-appearance:none;-moz-appearance:none;appearance:none}.banner{position:fixed;top:0;left:0;right:0;z-index:1000;display:flex;align-items:center;justify-content:center;gap:1rem;padding:.75rem 3rem .75rem 1rem;background-color:var(--first-color);color:var(--body-color);font-size:var(--small-font-size)}.banner__message{font-weight:var(--font-medium)}.banner__action{color:var(--body-color);font-weight:var(--font-semibold);text-decoration:underline}.banner__action:hover{opacity:.85}.banner__close{position:absolute;right:1rem;background:transparent;border:none;color:var(--body-color);font-size:1.25rem;cursor:pointer;padding:.25rem;display:flex;align-items:center;justify-content:center}.banner__close:hover{opacity:.85}@media screen and (max-width: 576px){.banner{flex-wrap:wrap;gap:.5rem;padding:.6rem 2rem .6rem 1rem;text-align:center}.banner__message{flex:1 1 100%}.banner__action{flex:0 0 auto}}body.light-theme{--title-color: hsl(var(--second-hue), 15%, 15%);--text-color: hsl(var(--second-hue), 8%, 35%);--body-color: hsl(var(--second-hue), 100%, 99%);--container-color: #fff}body.light-theme .scroll-header{box-shadow:0 2px 4px #0303031a}body.light-theme .nav__menu{background-color:hsla(var(--second-hue),32%,90%,.8)}body.light-theme .section__subtitle{color:var(--text-color)}body.light-theme .home__social-link{box-shadow:0 2px 8px hsla(var(--second-hue),48%,8%,.1)}body.light-theme .home__social:after,body.light-theme .footer__social-link{background-color:var(--title-color)}body.light-theme .home__social-link,body.light-theme .home__scroll,body.light-theme .button,body.light-theme .button:hover,body.light-theme .active-work,body.light-theme .footer__title,body.light-theme .footer__link,body.light-theme .footer__copy{color:var(--title-color)}body.light-theme .about__box{box-shadow:0 2px 8px hsla(var(--second-hue),48%,8%,.1)}body.light-theme .skills__content,body.light-theme .work__card,body.light-theme .contact__card{box-shadow:0 2px 16px hsla(var(--second-hue),48%,8%,.1)}body.light-theme .change-theme{color:var(--title-color)}body.light-theme::-webkit-scrollbar{background-color:hsl(var(--second-hue),8%,66%)}body.light-theme::-webkit-scrollbar-thumb{background-color:hsl(var(--second-hue),8%,54%)}body.light-theme::-webkit-scrollbar-thumb:hover{background-color:hsl(var(--second-hue),8%,44%)}.container{max-width:968px;margin-left:1rem;margin-right:1rem}.grid{display:grid;gap:1.25rem}.main{overflow:hidden}.section{padding:4.5rem 0 1rem}.section__title,.section__subtitle{text-align:center}.section__title{font-size:var(--h2-font-size);color:var(--first-color);margin-bottom:2rem}.section__subtitle{display:block;font-size:var(--smaller-font-size);color:var(--text-color-light)}.header{position:fixed;top:0;left:0;width:100%;background-color:var(--body-color);z-index:var(--z-fixed);transition:background-color .4s,box-shadow .4s}.nav{height:var(--header-height);display:flex;justify-content:space-between;align-items:center}.nav__logo{color:var(--first-color);font-weight:var(--font-medium);transition:color .4s}.nav__logo:hover{color:var(--first-color-alt)}.nav__menu{position:fixed;bottom:1rem;background-color:hsla(var(--second-hue),32%,16%,.8);width:90%;border-radius:4rem;padding:1rem 2.25rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:background-color .4s}.nav__list{display:flex;justify-content:space-between;align-items:center}.nav__link{color:var(--text-color);font-size:1.25rem;padding:.4rem;display:flex;border-radius:5rem}.active-link{background:linear-gradient(180deg,hsla(var(--first-hue),var(--sat),var(--lig),1),hsla(var(--first-hue),var(--sat),var(--lig),.2));box-shadow:0 0 16px hsla(var(--first-hue),var(--sat),var(--lig),.4);color:var(--title-color)}.scroll-header{box-shadow:0 4px 4px #0a0a0a4d}.home__container{position:relative;row-gap:4.5rem;padding-top:2rem}.home__data{text-align:center}.home__greeting,.home__education{font-size:var(--small-font-size);font-weight:var(--font-medium)}.home__greeting{display:block;color:var(--title-color);margin-bottom:.25rem}.home__education{color:var(--text-color);margin-bottom:2.5rem}.home__name{font-size:var(--biggest-font-size)}.home__img{width:260px}.home__handle{justify-self:center;width:190px;height:293px;background:linear-gradient(180deg,hsla(var(--first-hue),var(--sat),var(--lig),1),hsla(var(--first-hue),var(--sat),var(--lig),.2));border-radius:10rem 10rem 1rem 1rem;display:flex;align-items:flex-end;justify-content:center;overflow:hidden}.home__buttons{display:flex;justify-content:center;align-items:center;gap:1.5rem}.home__social,.home__scroll{position:absolute}.home__social{bottom:5rem;left:0;display:grid;row-gap:.5rem}.home__social-link{width:max-content;background-color:var(--container-color);color:var(--first-color);padding:.25rem;border-radius:.25rem;display:flex;font-size:1rem;transition:background-color .4s,color .4s}.home__social-link:hover{background-color:var(--first-color);color:#fff}.home__social:after{content:"";width:32px;height:2px;background-color:var(--first-color);transform:rotate(90deg) translate(16px,3px)}.home__scroll{color:var(--first-color);right:-1.5rem;bottom:4rem;display:grid;row-gap:2.25rem;justify-items:center}.home__scroll-icon{font-size:1.25rem}.home__scroll-name{font-size:var(--small-font-size);transform:rotate(-90deg)}.home__ai-btn{padding:.1rem .75rem;min-height:34px;display:inline-flex;align-items:center;justify-content:center}.home__ai-btn svg{width:20px;height:20px}.button{display:inline-block;background-color:var(--first-color);color:var(--body-color);padding:.75rem 1rem;border-radius:.5rem;font-weight:var(--font-medium);transition:background-color .4s}.button:hover{background-color:var(--first-color-alt);color:var(--body-color)}.button--ghost{background-color:transparent;border:2px solid var(--first-color);color:var(--first-color)}.about__container{row-gap:2.5rem}.about__img{width:220px;border-radius:1.5rem;justify-self:center}.about__data{text-align:center}.about__info{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;margin-bottom:2rem}.about__box{background-color:var(--container-color);border-radius:.75rem;padding:.75rem .5rem}.about__icon{font-size:1.5rem;color:var(--first-color);margin-bottom:.5rem}.about__title{font-size:var(--small-font-size)}.about__subtitle{font-size:var(--tiny-font-size)}.about__description{margin-bottom:2rem;text-align:justify}.about__buttons{display:flex;justify-content:start;align-items:center;gap:1rem;flex-wrap:wrap;margin-top:1.5rem}@media screen and (max-width: 320px){.about__buttons{flex-direction:column;justify-content:center;align-items:center}}.skills__container{row-gap:2rem;padding-top:1rem}.skills__content{background-color:var(--container-color);padding:1.5rem;border-radius:1.25rem}.skills__title{font-size:var(--normal-font-size);font-weight:var(--font-medium);color:var(--first-color);text-align:center;margin-bottom:1.5rem}.skills__box{display:flex;justify-content:center;column-gap:2.5rem}.skills__group{display:grid;align-content:center;row-gap:1rem}.skills__data{display:flex;column-gap:.5rem}.skills .bxs-badge-check{font-size:1rem;color:var(--first-color)}.skills__name{font-size:var(--normal-font-size);font-weight:var(--font-medium);line-height:18px}.skills__level{font-size:var(--tiny-font-size)}.cft__container{max-width:90vw;display:flex;align-items:stretch}.certificate__container{padding:1rem;justify-content:center;transition:all .3s ease-in-out}.certificate__card{background-color:var(--container-color);padding:1.25rem 1.5rem;border-radius:1.5rem;max-width:80vw;margin-bottom:3rem;height:auto}.certificate__img{width:40px;margin-bottom:1rem}.certificate__name{font-size:var(--normal-font-size);font-weight:var(--font-medium);margin-bottom:.25rem}.certificate__description{font-size:var(--small-font-size);margin-bottom:1rem}.certificate__button{width:max-content;color:var(--first-color);font-size:var(--small-font-size);display:flex;align-items:center;column-gap:.25rem;font-weight:700}.swiper-pagination-bullet{background-color:var(--text-color-light)}.swiper-pagination-bullet-active{background-color:var(--first-color)!important;border-color:var(--first-color)!important}.certificate__button-container{display:flex;justify-content:center;margin-top:1rem}.certificate__view-all{display:inline-block;background:none;border:none;color:var(--first-color);font-size:1rem;font-weight:500;cursor:pointer;padding:.5rem 1rem;transition:color .3s,transform .2s}.certificate__view-all:hover{color:var(--first-color-alt);transform:translateY(-2px)}.certificate__grid-view .swiper-wrapper{display:grid!important;grid-template-columns:repeat(2,1fr);row-gap:2rem;transform:none!important;justify-items:center;max-width:900px;margin:0 auto}.certificate__grid-view .certificate__card{width:100%!important;max-width:400px;margin:0!important;opacity:0;transform:translateY(30px) scale(.95);animation:slideInCard .6s ease-out forwards}.certificate__grid-view .certificate__card:nth-child(1){animation-delay:.1s}.certificate__grid-view .certificate__card:nth-child(2){animation-delay:.2s}.certificate__grid-view .certificate__card:nth-child(3){animation-delay:.3s}.certificate__grid-view .certificate__card:nth-child(4){animation-delay:.4s}.certificate__grid-view .certificate__card:nth-child(5){animation-delay:.5s}.certificate__grid-view .certificate__card:nth-child(6){animation-delay:.6s}.certificate__grid-view .certificate__card:nth-child(7){animation-delay:.7s}.certificate__grid-view .certificate__card:nth-child(8){animation-delay:.8s}.certificate__grid-view .swiper-pagination,.certificate__grid-view .swiper-button-next,.certificate__grid-view .swiper-button-prev{display:none!important}@keyframes slideInCard{0%{opacity:0;transform:translateY(30px) scale(.95)}60%{transform:translateY(-5px) scale(1.02)}to{opacity:1;transform:translateY(0) scale(1)}}.work__container{padding-top:1rem}.work__item{cursor:pointer;color:var(--title-color);padding:.25rem .75rem;font-weight:var(--font-medium);border-radius:.5rem;white-space:nowrap;display:inline-block;background:none;border:none;font-family:var(--body-font);font-size:var(--normal-font-size);transition:background-color .22s,color .22s}.work__item:hover{color:var(--first-color)}.work__card{background-color:var(--container-color);padding:1rem;border-radius:1rem;cursor:pointer;transition:transform .2s}.work__card:hover{transform:translateY(-2px)}.work__img{border-radius:1rem;margin-bottom:.6rem;width:100%;max-width:100%;aspect-ratio:16/9;min-height:105px;max-height:182px;object-fit:cover;display:block}.project-detail__image{width:100%;max-width:100%;height:auto;max-height:336px;object-fit:contain;border-radius:.7rem;display:block}.work__title{font-size:calc(var(--normal-font-size) * 1);font-weight:var(--font-medium);margin-bottom:.2rem}.work__button{width:max-content;color:var(--first-color);font-size:var(--small-font-size);display:flex;align-items:center;column-gap:.25rem}.work__button:hover .work__icon{transform:translate(.25rem)}.work__icon{font-size:1rem;transition:transform .4s}.active-work{background-color:var(--first-color);color:var(--body-color)}.active-work:hover{background-color:var(--first-color-alt);color:var(--body-color)!important}.work__status-icon{position:relative;color:#666;font-size:18px;margin-right:10px;display:flex;align-items:center;cursor:help;transition:color .3s}.work__status-icon:hover{color:#888}.work__youtube-icon{transition:color .3s}.work__youtube-icon:hover{color:#888!important}.work__deprecated-icon:after,.work__lock-icon:after,.work__toppick-icon:after{content:attr(data-tooltip);position:absolute;bottom:140%;left:50%;transform:translate(-50%);background:#1e1e23e6;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:#fff;padding:.6rem 1.2rem;border-radius:.625rem;font-size:var(--tiny-font-size);white-space:nowrap;opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s,transform .3s;pointer-events:none;z-index:1000;box-shadow:0 8px 32px #0006;min-width:220px;text-align:center;font-weight:400;line-height:1.4}.work__deprecated-icon:before,.work__lock-icon:before,.work__toppick-icon:before{content:"";position:absolute;bottom:120%;left:50%;transform:translate(-50%);border:7px solid transparent;border-top-color:#1e1e23e6;opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s;pointer-events:none;z-index:999}.work__deprecated-icon:hover:after,.work__deprecated-icon:hover:before,.work__lock-icon:hover:after,.work__lock-icon:hover:before,.work__toppick-icon:hover:after,.work__toppick-icon:hover:before{opacity:1;visibility:visible}.work__deprecated-icon:hover:after,.work__lock-icon:hover:after,.work__toppick-icon:hover:after{transform:translate(-50%) translateY(-3px)}body.light-theme .work__deprecated-icon:after,body.light-theme .work__lock-icon:after,body.light-theme .work__toppick-icon:after{background:#ffffffe6;color:var(--title-color);box-shadow:0 8px 32px #0003}body.light-theme .work__deprecated-icon:before,body.light-theme .work__lock-icon:before,body.light-theme .work__toppick-icon:before{border-top-color:#ffffffe6}.work__filter-container{max-width:640px}.work__filter-row{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:.25rem .5rem;padding-bottom:.55rem;border-bottom:1px solid hsl(var(--second-hue),8%,18%);margin:0 auto .75rem;width:100%;overflow-x:visible;scrollbar-width:none;-ms-overflow-style:none}.work__filter-row::-webkit-scrollbar{display:none}.work__tabs{display:contents}.work__tab{display:inline-flex;align-items:center;gap:.3rem;padding:.3rem .9rem;background:transparent;border:1.5px solid hsl(var(--second-hue),8%,28%);border-radius:.5rem;color:var(--text-color);font-family:var(--body-font);font-size:var(--small-font-size);font-weight:var(--font-medium);cursor:pointer;transition:border-color .22s,color .22s,background-color .22s;white-space:nowrap;line-height:1.4;flex-shrink:0}.work__tab:hover{border-color:var(--first-color);color:var(--first-color)}.work__tab.is-active{background-color:var(--first-color);border-color:var(--first-color);color:var(--body-color)}.work__tab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:1.05rem;height:1.05rem;background:var(--body-color);color:var(--first-color);border-radius:50%;font-size:.55rem;font-weight:700;line-height:1}.work__filter-sep{display:inline-block;width:5px;height:5px;border-radius:50%;background-color:var(--first-color);flex-shrink:0;margin:0 .2rem;opacity:.85;flex:0 0 auto}.work__utility-group{display:flex;align-items:center;gap:.35rem;flex:0 0 auto;order:0}.work__sort-btn{display:inline-flex;align-items:center;justify-content:center;padding:.3rem .55rem;background:transparent;border:1.5px solid hsl(var(--second-hue),8%,28%);border-radius:.5rem;color:var(--text-color);font-family:var(--body-font);font-size:var(--small-font-size);cursor:pointer;transition:border-color .22s,color .22s,background-color .22s;line-height:1.4}.work__sort-btn i{font-size:1rem;line-height:1}.work__sort-btn:hover{border-color:var(--first-color);color:var(--first-color)}.work__sort-btn.is-active{background-color:var(--first-color);border-color:var(--first-color);color:var(--body-color)}.work__canvas-btn{display:inline-flex;align-items:center;justify-content:center;padding:.3rem .55rem;background:transparent;border:1.5px solid hsl(var(--second-hue),8%,28%);border-radius:.5rem;color:var(--text-color);font-family:var(--body-font);font-size:var(--small-font-size);cursor:pointer;transition:border-color .22s,color .22s,background-color .22s;line-height:1.4}.work__canvas-btn i{font-size:1rem;line-height:1}.work__canvas-btn:hover{border-color:var(--first-color);color:var(--first-color)}.work__canvas-btn.is-active{background-color:var(--first-color);border-color:var(--first-color);color:var(--body-color)}.work__panel-zone{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:.5rem;width:100%;min-height:2.4rem;margin-bottom:2rem;animation:panelFade .18s ease}.work__panel-zone .work__item{font-size:var(--small-font-size)}.work__sort-opt{padding:.25rem .75rem;background:transparent;border:none;border-radius:.5rem;color:var(--title-color);font-family:var(--body-font);font-size:var(--small-font-size);font-weight:var(--font-medium);cursor:pointer;white-space:nowrap;transition:background-color .22s,color .22s}.work__sort-opt:hover{color:var(--first-color)}.work__sort-opt.is-active{background-color:var(--first-color);color:var(--body-color)}@keyframes panelFade{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}body.light-theme .work__filter-row{border-bottom-color:hsl(var(--second-hue),8%,86%)}body.light-theme .work__tab,body.light-theme .work__sort-btn,body.light-theme .work__canvas-btn{border-color:hsl(var(--second-hue),8%,72%)}@media screen and (max-width: 600px){.work__filter-sep{display:inline-block}.work__filter-row{flex-wrap:wrap}.work__utility-group{order:0;flex:0 0 auto;justify-content:flex-end;padding-top:0}.work__tabs{display:contents}}.work--canvas-mode{position:fixed!important;top:0!important;left:0!important;right:0!important;bottom:0!important;z-index:800!important;overflow-y:auto;background:var(--body-color);padding:1.5rem 1rem 5rem;margin:0!important;animation:canvasExpand .35s cubic-bezier(.4,0,.2,1) forwards}.work--canvas-mode .section__subtitle,.work--canvas-mode .section__title{display:none}@media screen and (max-width: 600px){.work--canvas-mode{padding-left:0;padding-right:0;padding-bottom:0;overflow-x:hidden}.work--canvas-mode .container{max-width:100vw;width:100vw;margin-left:0;margin-right:0;padding-left:.75rem;padding-right:.75rem}.work--canvas-mode{padding-left:.75rem;padding-right:.75rem}.work--canvas-mode .container{box-sizing:border-box}.work--canvas-mode .work__container{width:100%;max-width:100%;margin:0;padding:0}.work--canvas-mode .work__card{width:100%;max-width:calc(100vw - 1.5rem)}.work--canvas-mode .work__filter-container{max-width:100%}}.work--canvas-exiting{animation:canvasCollapse .3s cubic-bezier(.4,0,.2,1) forwards!important}@keyframes canvasExpand{0%{opacity:.6;transform:scale(.97)}to{opacity:1;transform:scale(1)}}@keyframes canvasCollapse{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.97)}}.contact__container{grid-template-columns:1fr;row-gap:3rem;padding-bottom:3rem}.contact__info{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;max-width:600px;margin:0 auto}.contact__card{background-color:var(--container-color);padding:1rem;border-radius:.75rem;text-align:center}.contact__card-icon{font-size:2rem;color:var(--title-color);margin-bottom:.25rem}.contact__card-title,.contact__card-data{font-size:var(--small-font-size)}.contact__card-title{font-weight:var(--font-medium)}.contact__card-data{display:block;margin-bottom:.75rem}.contact__button{color:var(--first-color);font-size:var(--small-font-size);display:flex;align-items:center;justify-content:center;column-gap:.25rem}.contact__button:hover .contact__button-icon{transform:translate(.25rem)}.contact__button-icon{font-size:1rem;transition:transform .4s}.footer{background-color:var(--first-color)}.footer__container{padding:2rem 0 6rem}.footer__title,.footer__link{color:var(--body-color)}.footer__title{text-align:center;margin-bottom:2rem}.footer__list{display:flex;justify-content:center;column-gap:1.5rem;margin-bottom:2rem}.footer__social{display:flex;justify-content:center;column-gap:1.25rem}.footer__social-link{background-color:var(--body-color);color:var(--first-color);padding:.25rem;border-radius:.25rem;font-size:1rem;display:inline-flex}.footer__copy{display:block;margin-top:4.5rem;color:var(--container-color);text-align:center;font-size:var(--smaller-font-size)}::-webkit-scrollbar{width:.6rem;border-radius:.5rem;background-color:hsl(var(--second-hue),8%,38%)}::-webkit-scrollbar-thumb{background-color:hsl(var(--second-hue),8%,26%);border-radius:.5rem}::-webkit-scrollbar-thumb:hover{background-color:hsl(var(--second-hue),8%,20%)}.avatar{position:fixed;z-index:1000;pointer-events:none}.avatar img{width:100%;height:100%;object-fit:contain;border-radius:50%}.page-loader{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:var(--body-color);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem;transition:opacity .6s ease,visibility .6s ease}.page-loader.is-hidden{opacity:0;visibility:hidden;pointer-events:none}.loader__logo{font-size:2rem;font-weight:var(--font-semibold);color:var(--first-color);letter-spacing:.05em}.loader__spinner{width:48px;height:48px;border:3px solid hsla(var(--first-hue),var(--sat),var(--lig),.2);border-top-color:var(--first-color);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loader__text{font-size:var(--small-font-size);color:var(--text-color-light)}.loader__progress{width:200px;height:3px;background:hsla(var(--first-hue),var(--sat),var(--lig),.15);border-radius:2px;overflow:hidden}.loader__bar{height:100%;width:0%;background:var(--first-color);border-radius:2px;transition:width .3s ease}.turnstile-gate{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9998;background:var(--body-color);display:flex;align-items:center;justify-content:center;padding:1.5rem;transition:opacity .6s ease,visibility .6s ease}.turnstile-gate.is-hidden{opacity:0;visibility:hidden;pointer-events:none}.turnstile-card{background:var(--container-color);border-radius:1.5rem;padding:2.5rem 2rem;text-align:center;max-width:400px;width:100%;box-shadow:0 20px 60px #0000004d}.turnstile-logo{font-size:1.75rem;font-weight:var(--font-semibold);color:var(--first-color);margin-bottom:.5rem}.turnstile-subtitle{font-size:var(--small-font-size);color:var(--text-color-light);margin-bottom:2rem}.turnstile-widget{display:flex;justify-content:center;margin-bottom:1.5rem}.turnstile-status{font-size:var(--small-font-size);color:var(--text-color-light);min-height:1.5em}.turnstile-error{color:#e05c5c;font-size:var(--small-font-size);margin-top:.75rem}.devtools-block{position:fixed;top:0;right:0;bottom:0;left:0;z-index:99999;background:var(--body-color);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:2rem;text-align:center}.devtools-block h1{font-size:var(--h1-font-size);color:var(--first-color)}.devtools-block p{color:var(--text-color);max-width:400px;line-height:1.6}.devtools-block i{font-size:4rem;color:var(--first-color);margin-bottom:.5rem}.skeleton{background:linear-gradient(90deg,var(--container-color) 25%,hsl(var(--second-hue),32%,16%) 50%,var(--container-color) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:.5rem}body.light-theme .skeleton{background:linear-gradient(90deg,#e8e8e8 25%,#f4f4f4,#e8e8e8 75%);background-size:200% 100%}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.project-detail__back{display:inline-flex;align-items:center;column-gap:.4rem;color:var(--first-color);font-size:var(--small-font-size);font-weight:var(--font-medium);margin-bottom:1.75rem;transition:color .3s}.project-detail__back i{font-size:1.1rem}.project-detail__back:hover{color:var(--first-color-alt)}.project-detail__header{position:relative;display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:2rem;flex-wrap:wrap}.project-detail__title{font-size:var(--h1-font-size);color:var(--title-color);font-weight:var(--font-semibold);margin:0}.project-detail__badges{position:absolute;top:0;right:0;display:flex;align-items:flex-start;column-gap:.6rem;flex-shrink:0;padding-top:.2rem}.project-detail__badge{position:relative;font-size:1.4rem;display:flex;align-items:center;cursor:help;color:var(--text-color-light);transition:color .3s}.project-detail__badge:hover{color:var(--text-color)}.project-detail__badge--top-pick i{color:#f5a623}.project-detail__badge--deprecated i{color:#e05c5c}.project-detail__badge--locked i{color:var(--text-color-light)}.project-detail__badge--open i{color:var(--first-color)}.project-detail__badge:after{content:attr(data-tooltip);position:absolute;bottom:140%;left:50%;transform:translate(-50%);background:#14141ceb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;padding:.5rem .9rem;border-radius:.5rem;font-size:var(--tiny-font-size);font-weight:400;line-height:1.45;white-space:normal;min-width:200px;text-align:center;opacity:0;visibility:hidden;transition:opacity .25s,visibility .25s;pointer-events:none;z-index:100;box-shadow:0 4px 20px #00000073}.project-detail__badge:before{content:"";position:absolute;bottom:118%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:#14141ceb;opacity:0;visibility:hidden;transition:opacity .25s,visibility .25s;pointer-events:none;z-index:100}.project-detail__badge:hover:after,.project-detail__badge:hover:before{opacity:1;visibility:visible}body.light-theme .project-detail__badge:after{background:#fffffff2;color:var(--title-color);box-shadow:0 4px 16px #00000026}body.light-theme .project-detail__badge:before{border-top-color:#fffffff2}.project-detail__content{display:grid;gap:2rem}.project-detail__image-container{width:100%}.project-detail__image{width:100%;height:auto;display:block;border-radius:1rem}.project-detail__info{display:grid;row-gap:1.5rem}.project-detail__section-title{font-size:var(--h3-font-size);color:var(--first-color);font-weight:var(--font-semibold);margin-bottom:.75rem}.project-detail__description{color:var(--text-color);font-size:var(--normal-font-size);line-height:1.7}.project-detail__keywords{display:flex;flex-wrap:wrap;gap:.5rem}.project-detail__keyword{padding:.35rem .9rem;background-color:transparent;border:1.5px solid var(--first-color);border-radius:.4rem;font-size:var(--small-font-size);color:var(--first-color);font-weight:var(--font-medium);white-space:nowrap}.project-detail__actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1.25rem}.project-detail__button{display:inline-flex;align-items:center;column-gap:.4rem;padding:.75rem 1.25rem;background-color:var(--first-color);color:var(--body-color);border-radius:.5rem;font-weight:var(--font-medium);font-size:var(--normal-font-size);transition:background-color .4s;text-decoration:none}.project-detail__button:hover{background-color:var(--first-color-alt);color:var(--body-color)}.project-detail__button--secondary{background-color:transparent;border:2px solid var(--first-color);color:var(--first-color)}.project-detail__button--secondary:hover{background-color:var(--first-color);color:var(--body-color)}.project-detail__loading,.project-detail__error{text-align:center;padding:5rem 1rem;color:var(--text-color)}.project-detail__loading i,.project-detail__error i{font-size:2.75rem;color:var(--first-color);display:block;margin-bottom:.75rem}.project-detail__loading i{animation:spin 1s linear infinite}.project-detail__error-title{font-size:var(--h2-font-size);color:var(--title-color);margin-bottom:.5rem}.project-detail__tagline{font-size:var(--small-font-size);color:var(--text-color-light);font-style:italic;margin:0}.project-detail__tagline-row{display:flex;align-items:center;justify-content:space-between;gap:.6rem;margin-top:.25rem;flex-wrap:wrap}.project-detail__platform-pills{display:flex;flex-wrap:wrap;gap:.35rem;flex-shrink:0}.project-detail__platform-pill{font-size:var(--small-font-size);font-weight:var(--font-medium);color:var(--body-color);background-color:var(--first-color);border-radius:.3rem;padding:.15rem .6rem;white-space:nowrap}.project-detail__title-col{flex:1;min-width:0}.project-detail__tech-section{margin-top:2rem;margin-bottom:3rem}.project-detail__tech-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem 2rem}.project-detail__tech-label{font-size:var(--tiny-font-size);font-weight:var(--font-semibold);color:var(--text-color-light);text-transform:uppercase;letter-spacing:.07em;margin-bottom:.4rem}.error-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:2rem;gap:1.5rem}.error-page .error-code{font-size:6rem;font-weight:var(--font-semibold);color:var(--first-color);line-height:1}.error-page .error-title{font-size:var(--h1-font-size);color:var(--title-color)}.error-page .error-text{color:var(--text-color);max-width:400px;line-height:1.6}.reveal-hidden{opacity:0;transform:translateY(40px);transition:opacity .7s ease,transform .7s ease}.reveal-visible{opacity:1;transform:translateY(0)}@media screen and (max-width: 320px){.nav__menu{padding:1rem 1.5rem}.home__buttons{flex-direction:column}.home__handle{width:150px;height:253px}.home__img{width:200px}.about__info{grid-template-columns:repeat(2,1fr)}.skills__box{column-gap:1rem}.skills__name{font-size:var(--small-font-size)}.contact__info{grid-template-columns:1fr;max-width:280px}.project-detail__tech-grid{grid-template-columns:1fr}}@media screen and (min-width: 576px){.nav__menu{width:328px;left:0;right:0;margin:0 auto}.about__info{grid-template-columns:repeat(3,140px);justify-content:center}.about__description{padding:0 5rem}.skills__container{justify-content:center}.skills__content{padding:2rem 4rem}.work__container{justify-content:center}}@media screen and (max-width: 576px){.work__filter-container{max-width:100%}.certificate__grid-view .swiper-wrapper{grid-template-columns:1fr;row-gap:1.5rem}.project-detail__title{font-size:var(--h2-font-size)}.project-detail__actions{flex-direction:column}.project-detail__button{width:100%;justify-content:center}.project-detail__tech-grid{grid-template-columns:1fr}}@media screen and (min-width: 767px){.work__container{grid-template-columns:repeat(2,max-content)}}@media screen and (min-width: 992px){.container{margin-left:auto;margin-right:auto}.section{padding:6.5rem 0 1rem}.section__title{margin-bottom:3.5rem}.nav{height:calc(var(--header-height) + 1rem)}.home__handle{width:290px;height:400px}.home__img{width:320px}.home__social-link{padding:.4rem;font-size:1.25rem}.home__social:after{transform:rotate(90deg) translate(16px)}.home__scroll-icon{font-size:2rem}.about__container{grid-template-columns:repeat(2,1fr);align-items:center;column-gap:4rem}.about__img{width:350px}.about__data{text-align:initial}.about__box{text-align:center;padding:1rem 1.25rem}.about__description{padding:0;margin-bottom:2.5rem}.skills__container{grid-template-columns:repeat(3,350px);column-gap:3rem}.work__container{gap:3rem}.work__card{padding:1.25rem}.work__img{margin-bottom:1rem}.work__title{margin-bottom:.5rem}.certificate__card{max-width:28vw}.footer__social-link{font-size:1.25rem;padding:.4rem;border-radius:.5rem}.project-detail__content{grid-template-columns:1fr 1fr;column-gap:3.5rem;align-items:start}.project-detail__image-container{position:sticky;top:5rem}}.devtools-block{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:var(--body-color);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;z-index:9999;color:var(--title-color)}.devtools-block i{font-size:4rem;color:var(--first-color);margin-bottom:1rem}.devtools-block h1{font-size:var(--h1-font-size);margin-bottom:1rem}.devtools-block p{font-size:var(--normal-font-size);color:var(--text-color);line-height:1.5}.avatar.svelte-1vov9ym.svelte-1vov9ym{position:fixed;width:60px;height:60px;z-index:1000;pointer-events:none;transition:transform .15s ease-out}.avatar.svelte-1vov9ym img.svelte-1vov9ym{width:100%;height:100%;object-fit:contain;border-radius:50%}@media screen and (max-width: 767px){.avatar.svelte-1vov9ym.svelte-1vov9ym{display:none}}
