:root{--bg-gradient-onyx:linear-gradient(to bottom right,#3f3f40 3%,#303030 97%);--bg-gradient-jet:linear-gradient(to bottom right,rgba(45,45,46,.25) 0%,rgba(27,27,29,0) 100%),#202022;--bg-gradient-yellow-1:linear-gradient(to bottom right,#ffda6b 0%,rgba(255,192,97,0) 50%);--bg-gradient-yellow-2:linear-gradient(135deg,rgba(255,218,107,.25) 0%,rgba(255,187,92,0) 59.86%),#202022;--border-gradient-onyx:linear-gradient(to bottom right,#404040 0%,rgba(64,64,64,0) 50%);--text-gradient-yellow:linear-gradient(to right,#ffdb70,#ffbb5c);--jet:#383838;--onyx:#2b2b2c;--eerie-black-1:#202022;--eerie-black-2:#1e1e1f;--smoky-black:#121212;--white-1:#fff;--white-2:#fafafa;--orange-yellow-crayola:#ffdb70;--vegas-gold:#ceb15a;--light-gray:#d6d6d6;--light-gray-70:rgba(214,214,214,.7);--bittersweet-shimmer:#b84c4c;--ff-poppins:"Poppins",sans-serif;--fs-1:24px;--fs-2:18px;--fs-3:17px;--fs-4:16px;--fs-5:15px;--fs-6:14px;--fs-7:13px;--fs-8:11px;--fw-300:300;--fw-400:400;--fw-500:500;--fw-600:600;--shadow-1:-4px 8px 24px rgba(0,0,0,.25);--shadow-2:0 16px 30px rgba(0,0,0,.25);--shadow-3:0 16px 40px rgba(0,0,0,.25);--shadow-4:0 25px 50px rgba(0,0,0,.15);--shadow-5:0 24px 80px rgba(0,0,0,.25);--transition-1:.25s ease;--transition-2:.5s ease-in-out}*,:before,:after{box-sizing:border-box;margin:0;padding:0}a{text-decoration:none}li{list-style:none}img,ion-icon,a,button,time,span{display:block}button{font:inherit;text-align:left;cursor:pointer;background:0 0;border:none}input,textarea{width:100%;font:inherit;background:0 0;display:block}::selection{background:var(--orange-yellow-crayola);color:var(--smoky-black)}:focus{outline-color:var(--orange-yellow-crayola)}html{font-family:var(--ff-poppins)}body{background:var(--smoky-black)}.sidebar,article{background:var(--eerie-black-2);border:1px solid var(--jet);box-shadow:var(--shadow-1);z-index:1;border-radius:20px;padding:15px}.separator{background:var(--jet);width:100%;height:1px;margin:16px 0}.icon-box{background:var(--border-gradient-onyx);width:30px;height:30px;color:var(--orange-yellow-crayola);box-shadow:var(--shadow-1);z-index:1;border-radius:8px;justify-content:center;align-items:center;font-size:16px;display:flex;position:relative}.icon-box:before{content:"";background:var(--eerie-black-1);border-radius:inherit;z-index:-1;position:absolute;top:1px;bottom:1px;left:1px;right:1px}.icon-box ion-icon{--ionicon-stroke-width:35px}article{display:none}article.active{animation:.5s backwards fade;display:block}@keyframes fade{0%{opacity:0}to{opacity:1}}.h2,.h3,.h4,.h5{color:var(--white-2);text-transform:capitalize}.h2{font-size:var(--fs-1)}.h3{font-size:var(--fs-2)}.h4{font-size:var(--fs-4)}.h5{font-size:var(--fs-7);font-weight:var(--fw-500)}.article-title{padding-bottom:7px;position:relative}.article-title:after{content:"";background:var(--text-gradient-yellow);border-radius:3px;width:30px;height:3px;position:absolute;bottom:0;left:0}.has-scrollbar::-webkit-scrollbar{width:5px;height:5px}.has-scrollbar::-webkit-scrollbar-track{background:var(--onyx);border-radius:5px}.has-scrollbar::-webkit-scrollbar-thumb{background:var(--orange-yellow-crayola);border-radius:5px}.has-scrollbar::-webkit-scrollbar-button{width:20px}.content-card{background:var(--border-gradient-onyx);box-shadow:var(--shadow-2);cursor:pointer;z-index:1;border-radius:14px;padding:45px 15px 15px;position:relative}.content-card:before{content:"";background:var(--bg-gradient-jet);border-radius:inherit;z-index:-1;position:absolute;top:1px;bottom:1px;left:1px;right:1px}main{min-width:259px;margin:15px 12px 75px}.sidebar{max-height:112px;transition:var(--transition-2);margin-bottom:15px;overflow:hidden}.sidebar.active{max-height:405px}.sidebar-info{justify-content:flex-start;align-items:center;gap:15px;display:flex;position:relative}.avatar-box{background:var(--bg-gradient-onyx);border-radius:20px}.info-content .name{color:var(--white-2);font-size:var(--fs-3);font-weight:var(--fw-500);letter-spacing:-.25px;margin-bottom:10px}.info-content .title{color:var(--white-1);background:var(--onyx);font-size:var(--fs-8);font-weight:var(--fw-300);border-radius:8px;width:max-content;padding:3px 12px}.info_more-btn{color:var(--orange-yellow-crayola);background:var(--border-gradient-onyx);box-shadow:var(--shadow-2);transition:var(--transition-1);z-index:1;border-radius:0 15px;padding:10px;font-size:13px;position:absolute;top:-15px;right:-15px}.info_more-btn:before{content:"";border-radius:inherit;background:var(--bg-gradient-jet);transition:var(--transition-1);z-index:-1;position:absolute;top:1px;bottom:1px;left:1px;right:1px}.info_more-btn:hover,.info_more-btn:focus{background:var(--bg-gradient-yellow-1)}.info_more-btn:hover:before,.info_more-btn:focus:before{background:var(--bg-gradient-yellow-2)}.info_more-btn span{display:none}.sidebar-info_more{opacity:0;visibility:hidden;transition:var(--transition-2)}.sidebar.active .sidebar-info_more{opacity:1;visibility:visible}.contacts-list{grid-template-columns:1fr;gap:16px;display:grid}.contact-item{align-items:center;gap:16px;min-width:100%;display:flex}.contact-info{width:calc(100% - 46px);max-width:calc(100% - 46px)}.contact-title{color:var(--light-gray-70);font-size:var(--fs-8);text-transform:uppercase;margin-bottom:2px}.contact-info :-webkit-any(.contact-link,time,address){color:var(--white-2);font-size:var(--fs-7)}.contact-info :-moz-any(.contact-link,time,address){color:var(--white-2);font-size:var(--fs-7)}.contact-info :is(.contact-link,time,address){color:var(--white-2);font-size:var(--fs-7)}.contact-info address{font-style:normal}.social-list{justify-content:flex-start;align-items:center;gap:15px;padding-bottom:4px;padding-left:7px;display:flex}.social-item .social-link{color:var(--light-gray-70);font-size:18px}.social-item .social-link:hover{color:var(--light-gray)}.navbar{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--jet);width:100%;box-shadow:var(--shadow-2);z-index:5;background:rgba(43,43,44,.75);border-radius:12px 12px 0 0;position:fixed;bottom:0;left:0}.navbar-list{flex-wrap:wrap;justify-content:center;align-items:center;padding:0 10px;display:flex}.navbar-link{color:var(--light-gray);font-size:var(--fs-8);transition:color var(--transition-1);padding:20px 7px}.navbar-link:hover,.navbar-link:focus{color:var(--light-gray-70)}.navbar-link.active{color:var(--orange-yellow-crayola)}.about .article-title{margin-bottom:15px}.about-text{color:var(--light-gray);font-size:var(--fs-6);font-weight:var(--fw-300);line-height:1.6}.about-text p{margin-bottom:15px}.service{margin-bottom:35px}.service-title{margin-bottom:20px}.service-list{grid-template-columns:1fr;gap:20px;display:grid}.service-item{background:var(--border-gradient-onyx);box-shadow:var(--shadow-2);z-index:1;border-radius:14px;padding:20px;position:relative}.service-item:before{content:"";background:var(--bg-gradient-jet);border-radius:inherit;z-index:-1;position:absolute;top:1px;bottom:1px;left:1px;right:1px}.service-icon-box{margin-bottom:10px}.service-icon-box img{margin:auto}.service-content-box{text-align:center}.service-item-title{margin-bottom:7px}.service-item-text{color:var(--light-gray);font-size:var(--fs-6);font-weight:var(--fw-3);line-height:1.6}.testimonials{margin-bottom:30px}.testimonials-title{margin-bottom:20px}.testimonials-list{scroll-behavior:smooth;overscroll-behavior-inline:contain;scroll-snap-type:inline mandatory;justify-content:flex-start;align-items:flex-start;gap:15px;margin:0 -15px;padding:25px 15px 35px;display:flex;overflow-x:auto}.testimonials-item{scroll-snap-align:center;min-width:100%}.testimonials-avatar-box{background:var(--bg-gradient-onyx);box-shadow:var(--shadow-1);border-radius:14px;position:absolute;top:0;left:0;transform:translate(15px,-25px)}.testimonials-item-title{margin-bottom:7px}.testimonials-text{color:var(--light-gray);font-size:var(--fs-6);font-weight:var(--fw-300);line-clamp:4;-webkit-line-clamp:4;-webkit-box-orient:vertical;line-height:1.6;display:-webkit-box;overflow:hidden}.modal-container{overscroll-behavior:contain;z-index:20;pointer-events:none;visibility:hidden;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:fixed;top:0;left:0;overflow-y:auto}.modal-container::-webkit-scrollbar{display:none}.modal-container.active{pointer-events:all;visibility:visible}.overlay{opacity:0;visibility:hidden;pointer-events:none;z-index:1;width:100%;height:100vh;transition:var(--transition-1);background:#0d0d0d;position:fixed;top:0;left:0}.overlay.active{opacity:.8;visibility:visible;pointer-events:all}.testimonials-modal{background:var(--eerie-black-2);border:1px solid var(--jet);box-shadow:var(--shadow-5);opacity:0;transition:var(--transition-1);z-index:2;border-radius:14px;margin:15px 12px;padding:15px;position:relative;transform:scale(1.2)}.modal-container.active .testimonials-modal{opacity:1;transform:scale(1)}.modal-close-btn{background:var(--onyx);width:32px;height:32px;color:var(--white-2);opacity:.7;border-radius:8px;justify-content:center;align-items:center;font-size:18px;display:flex;position:absolute;top:15px;right:15px}.modal-close-btn:hover,.modal-close-btn:focus{opacity:1}.modal-close-btn ion-icon{--ionicon-stroke-width:50px}.modal-avatar-box{background:var(--bg-gradient-onyx);width:max-content;box-shadow:var(--shadow-2);border-radius:14px;margin-bottom:15px}.modal-img-wrapper>img{display:none}.modal-title{margin-bottom:4px}.modal-content time{font-size:var(--fs-6);color:var(--light-gray-70);font-weight:var(--fw-300);margin-bottom:10px}.modal-content p{color:var(--light-gray);font-size:var(--fs-6);font-weight:var(--fw-300);line-height:1.6}.clients{margin-bottom:15px}.clients-list{scroll-behavior:smooth;overscroll-behavior-inline:contain;scroll-snap-type:inline mandatory;justify-content:flex-start;align-items:flex-start;gap:15px;margin:0 -15px;padding:25px;scroll-padding-inline:25px;display:flex;overflow-x:auto}.clients-item{scroll-snap-align:start;min-width:50%}.clients-item img{filter:grayscale();width:100%;transition:var(--transition-1)}.clients-item img:hover{filter:grayscale(0)}.article-title,.timeline{margin-bottom:30px}.timeline .title-wrapper{align-items:center;gap:15px;margin-bottom:25px;display:flex}.timeline-list{font-size:var(--fs-6);margin-left:45px}.timeline-item{position:relative}.timeline-item:not(:last-child){margin-bottom:20px}.timeline-item-title{font-size:var(--fs-6);margin-bottom:7px;line-height:1.3}.timeline-list span{color:var(--vegas-gold);font-weight:var(--fw-400);line-height:1.6}.timeline-item:not(:last-child):before{content:"";background:var(--jet);width:1px;height:calc(100% + 50px);position:absolute;top:-25px;left:-30px}.timeline-item:after{content:"";background:var(--text-gradient-yellow);width:6px;height:6px;box-shadow:0 0 0 4px var(--jet);border-radius:50%;position:absolute;top:5px;left:-33px}.timeline-text{color:var(--light-gray);font-weight:var(--fw-300);line-height:1.6}.skills-title{margin-bottom:20px}.skills-list{padding:20px}.skills-item:not(:last-child){margin-bottom:15px}.skill .title-wrapper{align-items:center;gap:5px;margin-bottom:8px;display:flex}.skill .title-wrapper data{color:var(--light-gray);font-size:var(--fs-7);font-weight:var(--fw-300)}.skill-progress-bg{background:var(--jet);border-radius:10px;width:100%;height:8px}.skill-progress-fill{background:var(--text-gradient-yellow);border-radius:inherit;height:100%}.projects{width:"100%";height:calc(100vh - 240px)}.filter-list{display:none}.filter-select-box{margin-bottom:25px;position:relative}.filter-select{background:var(--eerie-black-2);color:var(--light-gray);border:1px solid var(--jet);width:100%;font-size:var(--fs-6);font-weight:var(--fw-300);border-radius:14px;justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.filter-select.active .select-icon{transform:rotate(.5turn)}.select-list{background:var(--eerie-black-2);border:1px solid var(--jet);z-index:2;opacity:0;visibility:hidden;pointer-events:none;border-radius:14px;width:100%;padding:6px;transition:all .15s ease-in-out;position:absolute;top:calc(100% + 6px)}.filter-select.active+.select-list{opacity:1;visibility:visible;pointer-events:all}.select-item button{background:var(--eerie-black-2);color:var(--light-gray);font-size:var(--fs-6);font-weight:var(--fw-300);text-transform:capitalize;border-radius:8px;width:100%;padding:8px 10px}.select-item button:hover{--eerie-black-2:#323234}.project-list{grid-template-columns:1fr;gap:30px;margin-bottom:10px;display:grid}.project-item{display:none}.project-item.active{animation:.25s forwards scaleUp;display:block}@keyframes scaleUp{0%{transform:scale(.5)}to{transform:scale(1)}}.project-item>a{width:100%}.project-img{border-radius:16px;width:100%;height:200px;margin-bottom:15px;position:relative;overflow:hidden}.project-img:before{content:"";z-index:1;width:100%;height:100%;transition:var(--transition-1);background:0 0;position:absolute;top:0;left:0}.project-item>a:hover .project-img:before{background:rgba(0,0,0,.5)}.project-item-icon-box{--scale:.8;background:var(--jet);color:var(--orange-yellow-crayola);transform:translate(-50%,-50%)scale(var(--scale));opacity:0;z-index:1;transition:var(--transition-1);border-radius:12px;justify-content:center;align-items:center;padding:18px;font-size:20px;display:flex;position:absolute;top:50%;left:50%}.project-item>a:hover .project-item-icon-box{--scale:1;opacity:1}.project-item-icon-box .fi-eye{width:20px;height:-moz-fit-content;height:fit-content}.project-img img{object-fit:cover;width:100%;height:100%;transition:var(--transition-1)}.project-item>a:hover img{transform:scale(1.1)}.project-title,.project-category{margin-left:10px}.project-title{color:var(--white-2);font-size:var(--fs-5);font-weight:var(--fw-400);text-transform:capitalize;line-height:1.3}.project-category{color:var(--light-gray-70);font-size:var(--fs-6);font-weight:var(--fw-300)}.blog-posts{margin-bottom:10px}.blog-posts-list{grid-template-columns:1fr;gap:20px;display:grid}.blog-post-item>a{background:var(--border-gradient-onyx);height:100%;box-shadow:var(--shadow-4);z-index:1;border-radius:16px;position:relative}.blog-post-item>a:before{content:"";border-radius:inherit;background:var(--eerie-black-1);z-index:-1;position:absolute;top:1px;bottom:1px;left:1px;right:1px}.blog-banner-box{border-radius:12px;width:100%;height:200px;overflow:hidden}.blog-banner-box img{object-fit:cover;width:100%;height:100%;transition:var(--transition-1)}.blog-post-item>a:hover .blog-banner-box img{transform:scale(1.1)}.blog-content{padding:15px}.blog-meta{justify-content:flex-start;align-items:center;gap:7px;margin-bottom:10px;display:flex}.blog-meta :-webkit-any(.blog-category,time){color:var(--light-gray-70);font-size:var(--fs-6);font-weight:var(--fw-300)}.blog-meta :-moz-any(.blog-category,time){color:var(--light-gray-70);font-size:var(--fs-6);font-weight:var(--fw-300)}.blog-meta :is(.blog-category,time){color:var(--light-gray-70);font-size:var(--fs-6);font-weight:var(--fw-300)}.blog-meta .dot{background:var(--light-gray-70);border-radius:4px;width:4px;height:4px}.blog-item-title{transition:var(--transition-1);margin-bottom:10px;line-height:1.3}.blog-post-item>a:hover .blog-item-title{color:var(--orange-yellow-crayola)}.blog-text{color:var(--light-gray);font-size:var(--fs-6);font-weight:var(--fw-300);line-height:1.6}.mapbox{border:1px solid var(--jet);border-radius:16px;width:100%;height:250px;margin-bottom:30px;position:relative;overflow:hidden}.mapbox figure{height:100%}.mapbox iframe{filter:grayscale()invert();border:none;width:100%;height:100%}.contact-form{margin-bottom:10px}.form-title{margin-bottom:20px}.input-wrapper{grid-template-columns:1fr;gap:25px;margin-bottom:25px;display:grid}.form-input{color:var(--white-2);font-size:var(--fs-6);font-weight:var(--fw-400);border:1px solid var(--jet);border-radius:14px;outline:none;padding:13px 20px}.form-input::placeholder{font-weight:var(--fw-500)}.form-input:focus{border-color:var(--orange-yellow-crayola)}textarea.form-input{resize:vertical;height:120px;min-height:100px;max-height:200px;margin-bottom:25px}textarea.form-input::-webkit-resizer{display:none}.form-input:focus:invalid{border-color:var(--bittersweet-shimmer)}.form-btn{background:var(--border-gradient-onyx);width:100%;color:var(--orange-yellow-crayola);font-size:var(--fs-6);text-transform:capitalize;box-shadow:var(--shadow-3);z-index:1;transition:var(--transition-1);border-radius:14px;justify-content:center;align-items:center;gap:10px;padding:13px 20px;display:flex;position:relative}.form-btn:before{content:"";background:var(--bg-gradient-jet);border-radius:inherit;z-index:-1;transition:var(--transition-1);position:absolute;top:1px;bottom:1px;left:1px;right:1px}.form-btn ion-icon{font-size:16px}.form-btn:hover{background:var(--bg-gradient-yellow-1)}.form-btn:hover:before{background:var(--bg-gradient-yellow-2)}.form-btn:disabled{opacity:.7;cursor:not-allowed}.form-btn:disabled:hover{background:var(--border-gradient-onyx)}.form-btn:disabled:hover:before{background:var(--bg-gradient-jet)}@media (min-width:450px){.clients-item{min-width:calc(33.33% - 10px)}.project-img,.blog-banner-box{height:auto}}@media (min-width:580px){:root{--fs-1:32px;--fs-2:24px;--fs-3:26px;--fs-4:18px;--fs-6:15px;--fs-7:15px;--fs-8:12px}.sidebar,article{width:520px;margin-left:auto;margin-right:auto;padding:30px}.article-title{font-weight:var(--fw-600);padding-bottom:15px}.article-title:after{width:40px;height:5px}.icon-box{border-radius:12px;width:48px;height:48px;font-size:18px}main{margin-top:60px;margin-bottom:100px}.sidebar{max-height:180px;margin-bottom:30px}.sidebar.active{max-height:584px}.sidebar-info{gap:25px}.avatar-box{border-radius:30px}.avatar-box img{width:120px}.info-content .name{margin-bottom:15px}.info-content .title{padding:5px 18px}.info_more-btn{padding:10px 15px;top:-30px;right:-30px}.info_more-btn span{font-size:var(--fs-8);display:block}.info_more-btn ion-icon{display:none}.separator{margin:32px 0}.contacts-list{gap:20px}.contact-info{width:calc(100% - 64px);max-width:calc(100% - 64px)}.navbar{border-radius:20px 20px 0 0}.navbar-list{gap:20px}.navbar-link{--fs-8:14px}.about .article-title{margin-bottom:20px}.about-text{margin-bottom:40px}.service-item{justify-content:flex-start;align-items:flex-start;gap:18px;padding:30px;display:flex}.service-icon-box{margin-top:5px;margin-bottom:0}.service-content-box{text-align:left}.testimonials-title{margin-bottom:25px}.testimonials-list{gap:30px;margin:0 -30px;padding:30px 30px 35px}.content-card{padding:25px 30px 30px}.testimonials-avatar-box{border-radius:20px;transform:translate(30px,-30px)}.testimonials-avatar-box img{width:80px}.testimonials-item-title{margin-bottom:10px;margin-left:95px}.testimonials-text{line-clamp:2;-webkit-line-clamp:2}.modal-container{padding:20px}.testimonials-modal{border-radius:20px;justify-content:flex-start;align-items:stretch;gap:25px;padding:30px;display:flex}.modal-img-wrapper{flex-direction:column;align-items:center;display:flex}.modal-avatar-box{border-radius:18px;margin-bottom:0}.modal-avatar-box img{width:65px}.modal-img-wrapper>img{flex-grow:1;width:35px;display:block}.clients-list{gap:50px;margin:0 -30px;padding:45px;scroll-padding-inline:45px}.clients-item{min-width:calc(33.33% - 35px)}.timeline-list{margin-left:65px}.timeline-item:not(:last-child):before{left:-40px}.timeline-item:after{width:8px;height:8px;left:-43px}.skills-item:not(:last-child){margin-bottom:25px}.project-img,.blog-banner-box{border-radius:16px}.blog-posts-list{gap:30px}.blog-content{padding:25px}.mapbox{border-radius:18px;height:380px}.input-wrapper{gap:30px;margin-bottom:30px}.form-input{padding:15px 20px}textarea.form-input{margin-bottom:30px}.form-btn{--fs-6:16px;padding:16px 20px}.form-btn ion-icon{font-size:18px}}@media (min-width:768px){.sidebar,article{width:700px}.has-scrollbar::-webkit-scrollbar-button{width:100px}.contacts-list{grid-template-columns:1fr 1fr;gap:30px 15px}.navbar-link{--fs-8:15px}.testimonials-modal{gap:35px;max-width:680px}.modal-avatar-box img{width:80px}.article-title{padding-bottom:20px}.filter-select-box{display:none}.filter-list{justify-content:flex-start;align-items:center;gap:25px;margin-bottom:30px;padding-left:5px;display:flex}.filter-item button{color:var(--light-gray);font-size:var(--fs-5);transition:var(--transition-1)}.filter-item button:hover{color:var(--light-gray-70)}.filter-item button.active{color:var(--orange-yellow-crayola)}.project-list,.blog-posts-list,.input-wrapper{grid-template-columns:1fr 1fr}.form-btn{width:max-content;margin-left:auto}}@media (min-width:1024px){:root{--shadow-1:-4px 8px 24px rgba(0,0,0,.125);--shadow-2:0 16px 30px rgba(0,0,0,.125);--shadow-3:0 16px 40px rgba(0,0,0,.125)}.sidebar,article{width:950px;box-shadow:var(--shadow-5)}main{margin-bottom:60px}.main-content{width:max-content;margin:auto;position:relative}.navbar{width:max-content;box-shadow:none;border-radius:0 20px;padding:0 20px;position:absolute;top:0;bottom:auto;left:auto;right:0}.navbar-list{gap:30px;padding:0 20px}.navbar-link{font-weight:var(--fw-500)}.service-list{grid-template-columns:1fr 1fr;gap:20px 25px}.testimonials-item{min-width:calc(50% - 15px)}.clients-item{min-width:calc(25% - 38px)}.project-list{grid-template-columns:repeat(3,1fr)}.blog-banner-box{height:230px}}@media (min-width:1250px){body::-webkit-scrollbar{width:20px}body::-webkit-scrollbar-track{background:var(--smoky-black)}body::-webkit-scrollbar-thumb{border:5px solid var(--smoky-black);background:rgba(255,255,255,.1);border-radius:20px;box-shadow:inset 1px 1px rgba(255,255,255,.11),inset -1px -1px rgba(255,255,255,.11)}body::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.15)}body::-webkit-scrollbar-button{height:60px}.sidebar,article{width:auto}article{min-height:100%}main{justify-content:center;align-items:stretch;gap:25px;max-width:1200px;margin-left:auto;margin-right:auto;display:flex}.main-content{width:75%;min-width:75%;margin:0}.sidebar{z-index:1;height:100%;max-height:max-content;margin-bottom:0;padding-top:60px;position:-webkit-sticky;position:sticky;top:60px}.sidebar-info{flex-direction:column}.avatar-box img{width:150px}.info-content .name{white-space:nowrap;text-align:center}.info-content .title{margin:auto}.info_more-btn{display:none}.sidebar-info_more{opacity:1;visibility:visible}.contacts-list{grid-template-columns:1fr}.contact-info .contact-link{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.contact-info :-webkit-any(.contact-link,time,address){--fs-7:14px;font-weight:var(--fw-300)}.contact-info :-moz-any(.contact-link,time,address){--fs-7:14px;font-weight:var(--fw-300)}.contact-info :is(.contact-link,time,address){--fs-7:14px;font-weight:var(--fw-300)}.separator:last-of-type{opacity:0;margin:15px 0}.social-list{justify-content:center}.timeline-text{max-width:700px}}.portfolio-detail-page{background:var(--eerie-black-2);border:1px solid var(--jet);box-shadow:var(--shadow-1);z-index:1;border-radius:20px;padding:30px}.portfolio-detail-page:before{content:"";background:var(--bg-gradient-jet);border-radius:inherit;z-index:-1;position:absolute;top:1px;bottom:1px;left:1px;right:1px}.portfolio-navigation{border-bottom:1px solid var(--jet);justify-content:space-between;align-items:center;margin-bottom:30px;padding-bottom:20px;display:flex}.back-button{color:var(--orange-yellow-crayola);font-size:var(--fs-6);transition:var(--transition-1);align-items:center;gap:8px;text-decoration:none;display:flex}.portfolio-breadcrumb{font-size:var(--fs-7);align-items:center;gap:8px;display:flex}.portfolio-content{position:relative}.project-header{margin-bottom:40px}.project-hero{background:var(--jet);border-radius:16px;width:100%;height:400px;margin-bottom:25px;overflow:hidden}.project-hero-image{object-fit:cover;width:100%;height:100%;transition:var(--transition-1)}.project-info{justify-content:space-between;align-items:flex-start;gap:20px;display:flex}.project-links{gap:15px;display:flex}.btn-primary,.btn-secondary{font-size:var(--fs-6);font-weight:var(--fw-500);transition:var(--transition-1);border:1px solid transparent;border-radius:12px;align-items:center;gap:8px;padding:12px 20px;text-decoration:none;display:flex}.btn-primary{background:var(--bg-gradient-yellow-2);color:var(--white-2);border-color:var(--orange-yellow-crayola)}.btn-primary:hover{background:var(--orange-yellow-crayola);box-shadow:var(--shadow-2);color:var(--smoky-black);transform:translateY(-2px)}.btn-secondary{background:var(--border-gradient-onyx);color:var(--white-2);border-color:var(--jet)}.btn-secondary:hover{background:var(--jet);border-color:var(--orange-yellow-crayola);color:var(--orange-yellow-crayola)}.project-overview,.tech-stack,.screenshot-gallery,.lessons-learned{background:var(--border-gradient-onyx);border:1px solid var(--jet);border-radius:16px;margin-bottom:40px;padding:25px;position:relative}.project-overview:before,.tech-stack:before,.screenshot-gallery:before,.lessons-learned:before{content:"";background:var(--bg-gradient-jet);border-radius:inherit;z-index:-1;position:absolute;top:1px;bottom:1px;left:1px;right:1px}.project-overview h3,.tech-stack h3,.screenshot-gallery h3,.lessons-learned h3{color:var(--white-2);font-size:var(--fs-3);font-weight:var(--fw-500);background:var(--text-gradient-yellow);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:20px}.project-overview p,.lessons-learned p{color:var(--light-gray);font-size:var(--fs-6);margin-bottom:15px;line-height:1.6}.features-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-top:25px;display:grid}.feature-card{background:var(--eerie-black-1);border:1px solid var(--jet);text-align:center;transition:var(--transition-1);border-radius:12px;padding:20px}.feature-card:hover{border-color:var(--orange-yellow-crayola);transform:translateY(-5px)}.feature-icon{background:var(--bg-gradient-onyx);width:60px;height:60px;color:var(--orange-yellow-crayola);border-radius:50%;justify-content:center;align-items:center;margin:0 auto 15px;font-size:24px;display:flex}.feature-card h4{color:var(--white-2);font-size:var(--fs-5);font-weight:var(--fw-500);margin-bottom:10px}.feature-card p{color:var(--light-gray-70);font-size:var(--fs-7);line-height:1.4}.tech-stack-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;display:grid}.tech-item{background:var(--eerie-black-1);border:1px solid var(--jet);border-radius:12px;padding:20px}.tech-item strong{color:var(--orange-yellow-crayola);font-size:var(--fs-6);font-weight:var(--fw-500);margin-bottom:12px;display:block}.tech-item ul{margin:0;padding:0;list-style:none}.tech-item li{color:var(--light-gray);font-size:var(--fs-7);border-bottom:1px solid var(--jet);padding:4px 0}.tech-item li:last-child{border-bottom:none}.gallery-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;display:grid}.gallery-item{text-align:center}.gallery-image{object-fit:cover;width:100%;height:200px;transition:var(--transition-1);border-radius:12px;margin-bottom:12px}.gallery-image:hover{transform:scale(1.05)}.gallery-caption{color:var(--light-gray-70);font-size:var(--fs-7);font-style:italic}.lessons-content h4{color:var(--orange-yellow-crayola);font-size:var(--fs-5);font-weight:var(--fw-500);margin-top:20px;margin-bottom:12px}.lessons-content h4:first-child{margin-top:0}@media (max-width:768px){.portfolio-detail-page{padding:20px}.portfolio-navigation{flex-direction:column;align-items:flex-start;gap:15px}.project-info{flex-direction:column;align-items:stretch}.project-links{justify-content:center}.project-hero{height:250px}.features-grid,.tech-stack-grid,.gallery-grid{grid-template-columns:1fr}}@media (max-width:480px){.portfolio-detail-page{padding:15px}.project-links{flex-direction:column}.btn-primary,.btn-secondary{justify-content:center}}@keyframes shimmer{0%{background-position:-200px 0}to{background-position:calc(200px + 100%) 0}}.skeleton-item{background:linear-gradient(90deg,var(--eerie-black-1)0px,var(--jet)40px,var(--eerie-black-1)80px);background-size:200px;border-radius:8px;animation:1.5s linear infinite shimmer}.skeleton-article{background:var(--eerie-black-2);border:1px solid var(--jet);box-shadow:var(--shadow-1);border-radius:20px;padding:30px}.skeleton-title{border-bottom:3px solid var(--jet);width:-moz-fit-content;width:fit-content;margin-bottom:30px;padding-bottom:7px}.skeleton-h2{width:150px;height:32px}.skeleton-text{background:linear-gradient(90deg,var(--eerie-black-1)0px,var(--jet)40px,var(--eerie-black-1)80px);background-size:200px;border-radius:4px;height:16px;margin-bottom:12px;animation:1.5s linear infinite shimmer}.skeleton-paragraph{width:100%;height:16px}.skeleton-paragraph.short{width:70%}.skeleton-text-group{margin-bottom:40px}.skeleton-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;display:grid}.skeleton-card{background:var(--border-gradient-onyx);border:1px solid var(--jet);border-radius:16px;padding:20px;position:relative}.skeleton-card:before{content:"";background:var(--bg-gradient-jet);border-radius:inherit;z-index:-1;position:absolute;top:1px;bottom:1px;left:1px;right:1px}.skeleton-image{background:linear-gradient(90deg,var(--eerie-black-1)0px,var(--jet)40px,var(--eerie-black-1)80px);background-size:200px;border-radius:12px;height:150px;margin-bottom:15px;animation:1.5s linear infinite shimmer}.skeleton-card-content{padding:10px 0}.skeleton-card-title{width:80%;height:20px;margin-bottom:10px}.skeleton-card-text{width:60%;height:14px}.navbar .skeleton-item{background:var(--jet);width:60px;height:24px}@media (max-width:768px){.skeleton-grid{grid-template-columns:1fr}.skeleton-article{padding:20px}}.blog-post-page{background:var(--smoky-black-2)!important;min-height:100vh!important;color:var(--white-2)!important;width:100%!important;padding:20px!important;display:block!important}.blog-post-content{height:-moz-fit-content;height:fit-content}.post-navigation{border-bottom:1px solid var(--jet);margin-bottom:30px;padding-bottom:20px}.back-button{color:var(--orange-yellow-crayola);font-size:var(--fs-6);transition:var(--transition-1);align-items:center;gap:8px;margin-bottom:15px;text-decoration:none;display:inline-flex}.back-button:hover{color:var(--vegas-gold)}.post-breadcrumb{font-size:var(--fs-7);color:var(--light-gray-70);flex-wrap:wrap;align-items:center;gap:8px;display:flex}.breadcrumb-link{color:var(--orange-yellow-crayola);transition:var(--transition-1);text-decoration:none}.breadcrumb-link:hover{color:var(--vegas-gold)}.breadcrumb-separator{color:var(--light-gray)}.breadcrumb-current{color:var(--white-2);font-weight:var(--fw-500)}.post-header{margin-bottom:40px}.post-thumbnail{background:var(--border-gradient-onyx);border-radius:14px;margin-bottom:30px;padding:3px;overflow:hidden}.post-thumbnail-image{object-fit:cover;border-radius:12px;width:100%;height:400px}.post-meta{text-align:center}.post-category{justify-content:center;align-items:center;gap:10px;margin-bottom:20px;display:flex}.category-badge{background:var(--bg-gradient-yellow-1);color:var(--smoky-black-1);font-size:var(--fs-8);font-weight:var(--fw-500);text-transform:uppercase;letter-spacing:1px;border-radius:8px;padding:5px 15px}.featured-badge{background:var(--orange-yellow-crayola);color:var(--smoky-black-1);font-size:var(--fs-8);font-weight:var(--fw-500);text-transform:uppercase;border-radius:8px;padding:5px 12px}.post-title{font-size:var(--fs-2);font-weight:var(--fw-600);color:var(--white-1);margin-bottom:15px;line-height:1.3}.post-description{font-size:var(--fs-5);color:var(--light-gray);max-width:700px;margin-bottom:25px;margin-left:auto;margin-right:auto;line-height:1.6}.post-info{flex-wrap:wrap;justify-content:center;align-items:center;gap:25px;margin-bottom:20px;display:flex}.post-author,.post-date,.post-reading-time{font-size:var(--fs-7);color:var(--light-gray-70);align-items:center;gap:6px;display:flex}.post-tags{flex-wrap:wrap;justify-content:center;gap:10px;display:flex}.tag{background:var(--onyx);color:var(--light-gray);font-size:var(--fs-8);transition:var(--transition-1);border-radius:6px;padding:3px 10px}.tag:hover{background:var(--jet);color:var(--orange-yellow-crayola)}.post-content{width:100%!important;max-width:1200px!important;min-height:400px!important;margin:0 auto 60px!important;display:block!important}.prose{color:var(--white-2);line-height:1.7;display:block}.prose-heading{color:var(--white-1);font-weight:var(--fw-600);margin-top:40px;margin-bottom:20px;line-height:1.3}.prose-h1{font-size:var(--fs-2);margin-top:50px}.prose-h2{font-size:var(--fs-3);margin-top:45px}.prose-h3{font-size:var(--fs-4);margin-top:40px}.prose-h4{font-size:var(--fs-5);margin-top:35px}.prose-h5{font-size:var(--fs-6);margin-top:30px}.prose-h6{font-size:var(--fs-7);margin-top:25px}.prose-paragraph{font-size:var(--fs-6);color:var(--light-gray);margin-bottom:20px}.prose-strong{color:var(--white-1);font-weight:var(--fw-600)}.prose-em{color:var(--orange-yellow-crayola);font-style:italic}.prose-code{background:var(--onyx);color:var(--orange-yellow-crayola);border-radius:4px;padding:2px 6px;font-family:Courier New,monospace;font-size:.9em}.prose-link{color:var(--orange-yellow-crayola);transition:var(--transition-1);border-bottom:1px solid transparent;text-decoration:none}.prose-link:hover{color:var(--vegas-gold);border-bottom-color:var(--vegas-gold)}.prose-link-external:after{content:" ↗";opacity:.7;font-size:.8em}.prose-list{margin:20px 0;padding-left:0}.prose-list-unordered,.prose-list-ordered{list-style:none}.prose-list-item{color:var(--light-gray);margin-bottom:8px;padding-left:25px;position:relative}.prose-list-unordered>.prose-list-item:before{content:"•";color:var(--orange-yellow-crayola);position:absolute;top:0;left:8px}.prose-list-ordered>.prose-list-item:before{counter-increment:list-counter;content:counter(list-counter)".";color:var(--orange-yellow-crayola);font-weight:var(--fw-500);position:absolute;top:0;left:0}.prose-list-ordered{counter-reset:list-counter}.blog-placeholder{background:var(--border-gradient-onyx);border:1px solid var(--jet);border-radius:16px;justify-content:center;align-items:center;width:100%;height:200px;display:flex}.placeholder-content{opacity:.5;font-size:2rem}.loading-message,.error-message,.no-posts-message{text-align:center;color:var(--light-gray-70);padding:40px 20px}.error-message{color:var(--bittersweet-shimmer)}.prose-blockquote{border-left:4px solid var(--orange-yellow-crayola);background:var(--onyx);color:var(--light-gray-70);border-radius:0 8px 8px 0;margin:30px 0;padding:20px 25px;font-style:italic}.prose-blockquote p{margin:0}.prose-hr{background:var(--jet);border:none;height:1px;margin:40px 0}.prose-image-wrapper{text-align:center;margin:30px 0}.prose-image{border:3px solid var(--jet);border-radius:12px;max-width:100%;height:auto}.prose-caption{font-size:var(--fs-7);color:var(--light-gray-70);margin-top:10px;font-style:italic}.prose-table-wrapper{margin:30px 0;overflow-x:auto}.prose-table{border-collapse:collapse;background:var(--onyx);border-radius:8px;width:100%;overflow:hidden}.prose-table-header{background:var(--jet)}.prose-table-header-cell{text-align:left;font-weight:var(--fw-600);color:var(--white-1);border-bottom:2px solid var(--orange-yellow-crayola);padding:15px}.prose-table-cell{color:var(--light-gray);border-bottom:1px solid var(--jet);padding:12px 15px}.prose-table-row:hover{background:var(--smoky-black-3)}.code-block{background:var(--smoky-black-1);border:1px solid var(--jet);border-radius:12px;margin:25px 0;overflow:hidden}.code-header{background:var(--onyx);border-bottom:1px solid var(--jet);justify-content:space-between;align-items:center;padding:12px 20px;display:flex}.code-info{align-items:center;gap:15px;display:flex}.code-filename{color:var(--orange-yellow-crayola);font-size:var(--fs-7);font-weight:var(--fw-500)}.code-language{color:var(--light-gray-70);font-size:var(--fs-8);text-transform:uppercase;letter-spacing:1px}.copy-button{border:1px solid var(--jet);color:var(--light-gray);cursor:pointer;transition:var(--transition-1);font-size:var(--fs-8);background:0 0;border-radius:6px;align-items:center;gap:6px;padding:6px 12px;display:flex}.copy-button:hover{background:var(--jet);color:var(--orange-yellow-crayola);border-color:var(--orange-yellow-crayola)}.copy-text{font-size:var(--fs-8)}.code-body{overflow-x:auto}.code-body pre{color:var(--white-2);font-family:Courier New,Monaco,Cascadia Code,monospace;font-size:var(--fs-7);background:0 0;margin:0;padding:20px;line-height:1.6}.code-body code{color:inherit;background:0 0;border-radius:0;padding:0}.code-with-lines{display:flex}.line-numbers{background:var(--onyx);border-right:1px solid var(--jet);-webkit-user-select:none;-moz-user-select:none;user-select:none;flex-direction:column;padding:20px 10px 20px 20px;display:flex}.line-number{color:var(--light-gray-70);font-size:var(--fs-8);text-align:right;min-width:20px;line-height:1.6}.code-content{flex:1;overflow-x:auto}.code-content pre{padding:20px 20px 20px 15px}.post-footer{border-top:1px solid var(--jet);max-width:800px;margin:0 auto;padding-top:40px}.post-actions{flex-wrap:wrap;justify-content:center;gap:20px;margin-bottom:30px;display:flex}.btn-secondary,.btn-primary{font-size:var(--fs-6);font-weight:var(--fw-500);transition:var(--transition-1);cursor:pointer;border:none;border-radius:8px;padding:12px 24px;text-decoration:none}.btn-secondary{background:var(--onyx);color:var(--light-gray);border:1px solid var(--jet)}.btn-secondary:hover{background:var(--jet);color:var(--orange-yellow-crayola);border-color:var(--orange-yellow-crayola)}.btn-primary{background:var(--bg-gradient-yellow-1);color:var(--smoky-black-1)}.btn-primary:hover{background:var(--vegas-gold)}.post-update-info{text-align:center;font-size:var(--fs-8);color:var(--light-gray-70)}@media (max-width:768px){.blog-post-page{padding:15px}.post-info{flex-direction:column;gap:15px}.post-title{font-size:var(--fs-3)}.post-thumbnail-image{height:250px}.code-header{padding:10px 15px}.code-info{flex-direction:column;align-items:flex-start;gap:5px}.copy-button{padding:4px 8px}.code-body pre{font-size:var(--fs-8);padding:15px}.code-with-lines .line-numbers{padding:15px 8px 15px 15px}.code-with-lines .code-content pre{padding:15px 15px 15px 10px}.post-actions{flex-direction:column;align-items:center}.btn-secondary,.btn-primary{text-align:center;width:100%;max-width:280px}}.hljs{color:var(--white-2)!important;background:0 0!important}.hljs-keyword,.hljs-selector-tag,.hljs-literal,.hljs-section,.hljs-link{color:#569cd6!important}.hljs-function .hljs-keyword{color:#dcdcaa!important}.hljs-subst{color:var(--white-2)!important}.hljs-string,.hljs-title,.hljs-name,.hljs-type,.hljs-attribute,.hljs-symbol,.hljs-bullet,.hljs-addition,.hljs-variable,.hljs-template-tag,.hljs-template-variable{color:#ce9178!important}.hljs-comment,.hljs-quote,.hljs-deletion,.hljs-meta{color:#6a9955!important}.hljs-number,.hljs-regexp,.hljs-literal{color:#b5cea8!important}.hljs-built_in,.hljs-builtin-name,.hljs-class .hljs-title{color:#4ec9b0!important}.hljs-attr,.hljs-variable{color:#9cdcfe!important}.hljs-title.class_{color:#4ec9b0!important}.hljs-tag{color:#569cd6!important}.hljs-property{color:#9cdcfe!important}.hljs-selector-id,.hljs-selector-class{color:#d7ba7d!important}.hljs-emphasis{font-style:italic}.hljs-strong{font-weight:700}.hljs-tag .hljs-name{color:#569cd6!important}.hljs-tag .hljs-attr{color:#9cdcfe!important}.hljs-type{color:#4ec9b0!important}.prose-code{background:var(--onyx)!important;color:var(--orange-yellow-crayola)!important;border:1px solid var(--jet)!important;border-radius:4px!important;padding:2px 6px!important;font-family:Fira Code,Courier New,Monaco,Cascadia Code,monospace!important;font-size:.9em!important}
