@import "https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600&display=swap";
:root{--bg-gradient-onyx:linear-gradient(to bottom right,#3f3f40 3%,#303030 97%);--bg-gradient-jet:linear-gradient(to bottom right,#2d2d2e40 0%,#1b1b1d00 100%),#202022;--bg-gradient-yellow-1:linear-gradient(to bottom right,#ffda6b 0%,#ffc06100 50%);--bg-gradient-yellow-2:linear-gradient(135deg,#ffda6b40 0%,#ffbb5c00 59.86%),#202022;--border-gradient-onyx:linear-gradient(to bottom right,#404040 0%,#40404000 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:#d6d6d6b3;--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 #00000040;--shadow-2:0 16px 30px #00000040;--shadow-3:0 16px 40px #00000040;--shadow-4:0 25px 50px #00000026;--shadow-5:0 24px 80px #00000040;--transition-1:.25s ease;--transition-2:.5s ease-in-out}[data-theme=light]{--bg-gradient-onyx:linear-gradient(to bottom right,#ebebeb 3%,#e0e0e0 97%);--bg-gradient-jet:linear-gradient(to bottom right,#ebebeb80 0%,#e0e0e000 100%),#f2f2f2;--bg-gradient-yellow-1:linear-gradient(to bottom right,#ffd24c 0%,#ffad3300 50%);--bg-gradient-yellow-2:linear-gradient(135deg,#ffd24c33 0%,#fa30 60%),#f2f2f2;--border-gradient-onyx:linear-gradient(to bottom right,#d1d1d1 0%,#d1d1d100 50%);--text-gradient-yellow:linear-gradient(to right,#e6ac00,#c70);--jet:#d9d9d9;--onyx:#e6e6e6;--eerie-black-1:#f5f5f5;--eerie-black-2:#fafafa;--smoky-black:#f0f0f0;--white-1:#262626;--white-2:#333;--orange-yellow-crayola:#e6ac00;--vegas-gold:#9d822f;--light-gray:#595959;--light-gray-70:#595959b3;--bittersweet-shimmer:#b84c4c}[data-theme=light] .sidebar,[data-theme=light] article{box-shadow:0 4px 20px #00000014}[data-theme=light] .clients-item{background-color:#fff;border:1px solid #e0e0e0}[data-theme=light] .clients-item img{filter:grayscale(.5)}[data-theme=light] .chess-game-item{background:#f7f7f7;border-color:#e0e0e0}[data-theme=light] .mapbox iframe{filter:grayscale(.3)invert(0)}[data-theme=light] .navbar{background:#f5f5f5d9}[data-theme=light] .chess-title-badge{background:#e6911a}*,: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;inset: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;inset:1px}main{min-width:259px;margin:15px 12px 75px}.sidebar{max-height:140px;transition:var(--transition-2);margin-bottom:15px;animation:6s ease-in-out infinite sidebar-glow;overflow:hidden}@keyframes sidebar-glow{0%,to{box-shadow:var(--shadow-1),0 0 8px #ffdb7014,inset 0 0 0 1px #ffdb700f}50%{box-shadow:var(--shadow-1),0 0 18px #ffdb7026,inset 0 0 0 1px #ffdb7026}}.sidebar.active{max-height:580px}.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;flex-shrink:0;overflow:hidden}.avatar-box img{width:80px;height:auto;display:block}.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;inset: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 :is(.contact-link,time,address){color:var(--white-2);font-size:var(--fs-7);overflow-wrap:anywhere;word-break:break-all;white-space:normal}.contact-info address{word-break:normal;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)}.powered-by{text-align:center;padding:8px 0 4px}.powered-by-label{color:#666;text-transform:uppercase;letter-spacing:1.5px;margin-bottom:8px;font-size:.7rem}.powered-by-badges{justify-content:center;gap:8px;display:flex}.powered-by-badge{color:#999;background:#262626;border:1px solid #383838;border-radius:20px;align-items:center;gap:5px;padding:4px 10px;font-size:.72rem;font-weight:500;text-decoration:none;transition:color .2s,border-color .2s,background .2s;display:inline-flex}.powered-by-badge:hover{color:#e6e6e6;background:#2e2e2e;border-color:#595959}.powered-by-badge svg{flex-shrink:0;width:14px;height:14px}.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:#2b2b2cbf;border-radius:12px 12px 0 0;position:fixed;bottom:0;left:0}.navbar-list{-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-wrap:nowrap;justify-content:center;align-items:center;padding:0 10px;display:flex;overflow-x:auto}.navbar-list::-webkit-scrollbar{display:none}.navbar-link{color:var(--light-gray);font-size:var(--fs-8);transition:color var(--transition-1);white-space:nowrap;padding:20px 7px;position:relative}.navbar-link:after{content:"";background:var(--orange-yellow-crayola);border-radius:1px;width:0;height:2px;transition:width .3s,left .3s;position:absolute;bottom:14px;left:50%}.navbar-link:hover:after,.navbar-link:focus:after{width:60%;left:20%}.navbar-link.active:after{width:100%;left:0}.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}.about-stats{margin-bottom:30px}.stats-row{background:var(--border-gradient-onyx);z-index:1;border-radius:14px;justify-content:center;align-items:center;gap:0;padding:20px 10px;display:flex;position:relative}.stats-row:before{content:"";background:var(--bg-gradient-jet);border-radius:inherit;z-index:-1;position:absolute;inset:1px}.stat-item{text-align:center;flex-direction:column;flex:1;align-items:center;gap:4px;min-width:0;display:flex}.counter-value{font-size:1.6rem;font-weight:var(--fw-600);background:var(--text-gradient-yellow);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;line-height:1.2}.stat-label{color:var(--light-gray-70);text-transform:uppercase;letter-spacing:.8px;font-size:.7rem;font-weight:var(--fw-400);white-space:nowrap}.stat-separator{background:var(--jet);flex-shrink:0;width:1px;height:36px}.download-cv-btn{color:#141414;background:#ceb15a;border-radius:8px;justify-content:center;align-items:center;gap:8px;width:100%;margin-bottom:16px;padding:10px 24px;font-size:14px;font-weight:600;text-decoration:none;transition:background .25s,transform .15s;display:flex}.download-cv-btn:hover{background:#bc9b38;transform:translateY(-1px)}.download-cv-btn ion-icon{font-size:18px}.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;inset: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-header{justify-content:space-between;align-items:baseline;margin-bottom:20px;display:flex}.testimonials-title{margin-bottom:0}.testimonials-tagline{color:var(--light-gray-70);font-size:.78rem;font-weight:var(--fw-300);margin-top:4px}.testimonials-count{font-size:var(--fs-8);color:var(--light-gray-70);font-weight:var(--fw-400)}.testimonials-carousel{position:relative}.testimonials-track{min-height:200px;position:relative;overflow:hidden}.testimonials-slide{opacity:0;pointer-events:none;transition:opacity .45s,transform .45s;position:absolute;inset:0;transform:translate(30px)}.testimonials-slide.active{opacity:1;pointer-events:all;position:relative;transform:translate(0)}.testimonials-avatar-box{background:var(--bg-gradient-onyx);box-shadow:var(--shadow-1);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;display:flex;overflow:hidden}.testimonials-avatar-box img{object-fit:cover;object-position:top center;width:100%;height:100%}.testimonials-initials-box{color:#73480d;letter-spacing:.5px;width:48px;height:48px;box-shadow:var(--shadow-1);background:linear-gradient(135deg,#ffdb70 0%,#ffbb5c 100%);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:16px;font-weight:700;display:flex}.testimonials-card{cursor:default;padding:20px}.testimonials-card-header{align-items:center;gap:14px;margin-bottom:16px;display:flex}.testimonials-card-info{flex:1;min-width:0}.testimonials-item-title{font-size:var(--fs-6);margin-bottom:2px;line-height:1.3}.testimonials-subtitle{color:var(--light-gray-70);font-size:.78rem;line-height:1.4;display:block}.testimonials-date{color:var(--light-gray-70);margin-top:2px;font-size:.7rem;display:block}.testimonials-quote-icon{opacity:.6;flex-shrink:0;align-self:flex-start;width:36px}.testimonials-quote{color:var(--light-gray);font-size:var(--fs-6);font-weight:var(--fw-300);border-left:3px solid var(--vegas-gold);overflow-wrap:break-word;word-break:break-word;margin:0;padding-left:16px;font-style:italic;line-height:1.6}.testimonials-nav{pointer-events:none;z-index:2;justify-content:space-between;display:flex;position:absolute;top:50%;left:-6px;right:-6px;transform:translateY(-50%)}.testimonials-nav-btn{background:var(--eerie-black-2);border:1px solid var(--jet);width:32px;height:32px;color:var(--light-gray);cursor:pointer;pointer-events:all;border-radius:50%;justify-content:center;align-items:center;font-size:16px;transition:background .2s,color .2s,border-color .2s;display:flex}.testimonials-nav-btn:hover{background:var(--jet);color:var(--orange-yellow-crayola);border-color:var(--orange-yellow-crayola)}.testimonials-dots{justify-content:center;align-items:center;gap:8px;margin-top:16px;display:flex}.testimonials-dot{background:var(--jet);cursor:pointer;border:none;border-radius:50%;width:8px;height:8px;padding:0;transition:background .3s,transform .3s}.testimonials-dot.active{background:var(--orange-yellow-crayola);transform:scale(1.3)}.testimonials-dot:hover:not(.active){background:var(--light-gray-70)}.testimonials-cta{background:var(--bg-gradient-jet);border:1px solid var(--jet);text-align:center;font-size:var(--fs-7);color:var(--light-gray);border-radius:14px;margin-top:20px;padding:16px 20px;line-height:1.6}.testimonials-cta a{color:var(--vegas-gold);font-weight:var(--fw-500);text-decoration:none}.testimonials-cta a:hover{text-decoration:underline}.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-marquee-wrapper{-webkit-user-select:none;user-select:none;margin:0 -15px;padding:25px 0;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,#0000,#000 8% 92%,#0000);mask-image:linear-gradient(90deg,#0000,#000 8% 92%,#0000)}.clients-marquee{will-change:transform;align-items:flex-start;gap:15px;width:max-content;margin:0;padding:0 15px;list-style:none;display:flex}.clients-item{background-color:#fff;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:150px;min-width:150px;height:80px;padding:10px;display:flex;overflow:hidden}.clients-item img{object-fit:contain;filter:grayscale();width:auto;max-width:130px;height:auto;max-height:60px;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-address{color:#ffdb70;align-items:center;gap:4px;margin-top:2px;margin-left:0;font-size:.8rem;font-weight:500;display:inline-flex}.timeline-address ion-icon{font-size:13px}.timeline-text{color:var(--light-gray);font-weight:var(--fw-300);line-height:1.6}.skills-title{margin-bottom:20px}.skills-grid{grid-template-columns:1fr;gap:16px;margin-bottom:24px;display:grid}.skill-category-card{background:var(--bg-gradient-jet);border:1px solid var(--jet);transition:var(--transition-1);border-radius:14px;padding:18px 20px}.skill-category-card:hover{border-color:var(--orange-yellow-crayola);box-shadow:0 0 0 1px #ffdb701a}.skill-category-header{align-items:center;gap:10px;margin-bottom:14px;display:flex}.skill-category-header ion-icon{color:var(--orange-yellow-crayola);flex-shrink:0;font-size:20px}.skill-category-header .h5{color:var(--white-1);font-size:var(--fs-6);font-weight:var(--fw-500);text-transform:uppercase;letter-spacing:1px}.skill-tags{flex-wrap:wrap;gap:8px;display:flex}.skill-tag{font-size:var(--fs-8);font-weight:var(--fw-400);color:var(--light-gray);white-space:nowrap;transition:var(--transition-1);background:#ffffff0a;border:1px solid #ffffff14;border-radius:50px;padding:5px 14px;display:inline-block}.skill-tag:hover{color:var(--orange-yellow-crayola);background:#ffdb7014;border-color:#ffdb7040}.skills-core-bar{margin-top:8px}.skills-bar-heading{color:var(--white-2);font-weight:var(--fw-500);text-transform:uppercase;letter-spacing:1px;font-size:var(--fs-7);margin-bottom:16px}.skills-bar-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%}.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{aspect-ratio:16/9;background:#262626;border-radius:16px;width:100%;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:#00000080}.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;padding:18px;font-size:20px;position:absolute;top:50%;left:50%}.project-item>a:hover .project-item-icon-box{--scale:1;opacity:1}.project-item-icon-box ion-icon{--ionicon-stroke-width:50px}.project-img img{object-fit:cover;width:100%;height:100%;transition:transform .5s cubic-bezier(.25,.46,.45,.94)}.project-item>a:hover .project-img img{transform:scale(1.08)}.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;inset:1px}.blog-banner-box{border-radius:12px;width:100%;height:200px;position:relative;overflow:hidden}.blog-pin-badge{z-index:1;background:var(--orange-yellow-crayola);color:var(--smoky-black);font-size:11px;font-weight:var(--fw-500);border-radius:6px;align-items:center;gap:4px;padding:3px 10px;display:inline-flex;position:absolute;top:10px;left:10px}.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{flex-wrap:wrap;justify-content:flex-start;align-items:center;gap:6px 7px;margin-bottom:10px;display:flex}.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;flex-shrink:0;width:4px;height:4px}.blog-read-time{color:var(--light-gray-70);font-size:var(--fs-6);font-weight:var(--fw-300)}.blog-read-badge{color:var(--light-gray-70);align-items:center;gap:4px;margin-bottom:10px;font-size:.68rem;display:inline-flex}.blog-read-badge ion-icon{font-size:12px}.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;inset: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)}.form-result{font-size:var(--fs-7);font-weight:var(--fw-400);border-radius:8px;margin-top:12px;padding:10px 14px}.form-result-success{color:#67e495;background:#67e4951a;border:1px solid #67e49533}.form-result-error{color:#e46767;background:#e467671a;border:1px solid #e4676733}.typing-text{display:inline}.typing-cursor{color:var(--orange-yellow-crayola);font-weight:var(--fw-300);margin-left:1px;animation:.7s step-end infinite blink-cursor;display:inline-block}@keyframes blink-cursor{0%,to{opacity:1}50%{opacity:0}}.info-content .title{min-width:140px;min-height:22px}.availability-badge{font-size:.68rem;font-weight:var(--fw-500);color:#47d17a;letter-spacing:.3px;background:#2eb8601a;border:1px solid #2eb86040;border-radius:20px;align-items:center;gap:6px;margin-top:8px;padding:4px 12px;display:inline-flex}.availability-dot{background:#33cc6b;border-radius:50%;width:7px;height:7px;animation:2s ease-in-out infinite pulse-dot}@keyframes pulse-dot{0%,to{opacity:1;box-shadow:0 0 #33cc6b66}50%{opacity:.7;box-shadow:0 0 0 5px #33cc6b00}}.theme-toggle-btn{background:var(--jet);width:100%;color:var(--light-gray);cursor:pointer;border:1px solid #0000;border-radius:8px;justify-content:center;align-items:center;gap:8px;margin-bottom:12px;padding:8px 24px;font-size:13px;font-weight:500;transition:background .25s,color .25s,border-color .25s;display:flex}.theme-toggle-btn:hover{border-color:var(--orange-yellow-crayola);color:var(--orange-yellow-crayola)}.theme-toggle-btn ion-icon{font-size:16px}.scroll-top-btn{background:var(--orange-yellow-crayola);width:42px;height:42px;color:var(--smoky-black);cursor:pointer;z-index:10;opacity:0;pointer-events:none;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:20px;transition:opacity .3s,transform .3s,background .2s;display:flex;position:fixed;bottom:80px;right:20px;transform:translateY(20px);box-shadow:0 4px 12px #0000004d}.scroll-top-btn.visible{opacity:1;pointer-events:all;transform:translateY(0)}.scroll-top-btn:hover{background:var(--vegas-gold)}article.active.page-enter{animation:.4s backwards pageSlideIn}article.active.page-exit{animation:.2s forwards pageSlideOut}@keyframes pageSlideIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes pageSlideOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-8px)}}.navbar{transition:transform .3s,opacity .3s}.navbar.navbar-hidden{opacity:0;pointer-events:none;transform:translateY(100%)}.lazy-image-wrapper{width:100%;height:100%;position:relative;overflow:hidden}.lazy-image-wrapper img{object-fit:cover;opacity:0;width:100%;height:100%;transition:opacity .4s}.lazy-image-wrapper.loaded img{opacity:1}.project-img .lazy-image-wrapper{position:absolute;inset:0}.skeleton-shimmer{border-radius:inherit;background:linear-gradient(90deg,#262626 25%,#333 50%,#262626 75%) 0 0/200% 100%;animation:1.5s ease-in-out infinite shimmer;position:absolute;inset:0}[data-theme=light] .skeleton-shimmer{background:linear-gradient(90deg,#e6e6e6 25%,#f2f2f2 50%,#e6e6e6 75%) 0 0/200% 100%}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.project-tech-tags{flex-wrap:wrap;gap:4px;margin:8px 10px 4px;display:flex}.project-tech-tag{color:var(--orange-yellow-crayola);white-space:nowrap;letter-spacing:.3px;background:#ffdb7014;border:1px solid #ffdb7033;border-radius:20px;padding:2px 8px;font-size:.62rem;font-weight:500;display:inline-block}.skills-radar-section{margin-top:8px}.skills-radar-card{background:var(--border-gradient-onyx);box-shadow:var(--shadow-2);z-index:1;border-radius:14px;justify-content:center;align-items:center;padding:24px;display:flex;position:relative}.skills-radar-card:before{content:"";background:var(--bg-gradient-jet);border-radius:inherit;z-index:-1;position:absolute;inset:1px}.radar-chart{width:100%;max-width:340px;height:auto}.radar-grid{fill:none;stroke:var(--jet);stroke-width:.5px}.radar-axis{stroke:var(--jet);stroke-width:.5px}.radar-data{fill:#ffdb7026}.radar-data-stroke{fill:none;stroke:var(--orange-yellow-crayola);stroke-width:2px}.radar-dot{fill:var(--orange-yellow-crayola)}.radar-data-group{opacity:0;transition:opacity .8s,transform 1s cubic-bezier(.22,1,.36,1);transform:scale(0)}.radar-data-group.radar-animated{opacity:1;transform:scale(1)}.radar-label{fill:var(--light-gray);font-size:9px;font-weight:500}.form-field{position:relative}.form-input-error{border-color:#c33!important}.form-error{color:#e05252;margin-top:4px;padding-left:2px;font-size:.72rem;animation:.25s errorFadeIn;display:block}@keyframes errorFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.site-footer{border-top:1px solid var(--jet);text-align:center;margin-top:30px;padding:24px 16px}.footer-content{flex-direction:column;align-items:center;gap:12px;display:flex}.footer-copy{color:var(--light-gray-70);font-size:.75rem}.footer-links{flex-wrap:wrap;justify-content:center;gap:8px 16px;display:flex}.footer-links button,.footer-links a{color:var(--light-gray);cursor:pointer;background:0 0;border:none;padding:0;font-size:.75rem;text-decoration:none;transition:color .2s}.footer-links button:hover,.footer-links a:hover{color:var(--orange-yellow-crayola)}@media (max-width:400px){main{margin:10px 8px 75px}.sidebar,article{padding:12px}.stats-row{padding:16px 6px}.counter-value{font-size:1.3rem}.stat-label{letter-spacing:.5px;font-size:.6rem}.stat-separator{height:28px}.chess-game-item{padding:12px}.chess-game-players{flex-direction:column;align-items:flex-start;gap:6px;font-size:.82rem}.chess-vs{align-self:center;padding:2px 0}.chess-game-meta{gap:6px;font-size:.72rem}.chess-game-footer{flex-direction:column;align-items:flex-start;gap:6px}.gallery-nav{width:32px;height:32px;font-size:16px}.gallery-nav-prev{left:6px}.gallery-nav-next{right:6px}.gallery-body{height:35vh;min-height:180px;padding:8px}.gallery-footer{padding:10px 12px}.gallery-description{padding:0 12px 10px;font-size:.78rem}.gallery-thumbnails{padding:0 12px 10px}.gallery-thumb{width:44px;height:32px}.testimonials-card{padding:16px}.testimonials-card-header{gap:10px}.testimonials-quote{font-size:var(--fs-7);padding-left:12px}.hobby-card{padding:14px}.pagination{gap:4px}.page-btn{min-width:28px;height:28px;padding:0 6px;font-size:.72rem}.blog-content{padding:12px}.skill-category-card{padding:14px 16px}.skill-tag{padding:4px 10px;font-size:10px}}@media (min-width:450px){.clients-item{min-width:150px}.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-inline: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:230px;margin-bottom:30px}.sidebar.active{max-height:750px}.sidebar-info{gap:25px}.avatar-box{border-radius:30px}.avatar-box img{width:120px;height:auto}.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}.stats-row{padding:24px 16px}.counter-value{font-size:2rem}.stat-label{letter-spacing:1px;font-size:.75rem}.stat-separator{height:44px}.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-card{padding:24px}.testimonials-avatar-box{border-radius:50%;width:52px;height:52px}.testimonials-initials-box{width:52px;height:52px;font-size:17px}.testimonials-nav{left:-12px;right:-12px}.testimonials-nav-btn{width:36px;height:36px;font-size:18px}.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-marquee-wrapper{margin:0 -30px;padding:45px 0}.clients-marquee{gap:30px;padding:0 30px}.clients-item{min-width:160px}.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}.skills-grid{grid-template-columns:repeat(2,1fr)}.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 #00000020;--shadow-2:0 16px 30px #00000020;--shadow-3:0 16px 40px #00000020}.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;inset:0 0 auto auto}.navbar-list{gap:30px;padding:0 20px}.navbar-link{font-weight:var(--fw-500)}.service-list{grid-template-columns:1fr 1fr;gap:20px 25px}.clients-item{min-width:170px}.project-list{grid-template-columns:repeat(3,1fr)}.blog-banner-box{height:230px}.navbar.navbar-hidden{opacity:1;pointer-events:all;transform:none}.scroll-top-btn{bottom:30px}}@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:#ffffff1a;border-radius:20px;box-shadow:inset 1px 1px #ffffff1c,inset -1px -1px #ffffff1c}body::-webkit-scrollbar-thumb:hover{background:#ffffff26}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-inline: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:sticky;top:60px}.sidebar-info{flex-direction:column}.avatar-box img{width:150px;height:auto}.info-content .name{white-space:normal;text-align:center;word-break:break-word}.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 :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}.skills-grid{grid-template-columns:repeat(3,1fr)}}.image-popup-overlay{z-index:1000;cursor:pointer;background:#000000bf;justify-content:center;align-items:center;width:100%;height:100%;animation:.2s fadeIn;display:flex;position:fixed;top:0;left:0}.image-popup-content{cursor:default;background:#fff;border-radius:14px;justify-content:center;align-items:center;max-width:90vw;max-height:90vh;padding:24px;animation:.25s popIn;display:flex;position:relative}.image-popup-content img{object-fit:contain;border-radius:8px;width:auto;max-width:420px;height:auto;max-height:70vh}.image-popup-close{color:#d6d6d6;cursor:pointer;z-index:1;background:#383838;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:18px;transition:background .2s;display:flex;position:absolute;top:-12px;right:-12px}.image-popup-close:hover{background:#595959}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes popIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.gallery-overlay{z-index:1000;cursor:pointer;background:#000c;justify-content:center;align-items:center;padding:10px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.gallery-popup{cursor:default;background:#202022;border:1px solid #383838;border-radius:16px;flex-direction:column;width:100%;max-width:900px;max-height:90vh;animation:.25s popIn;display:flex;position:relative;overflow:hidden}.gallery-close-btn{color:#d6d6d6;cursor:pointer;z-index:2;background:#383838e6;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:18px;transition:background .2s;display:flex;position:absolute;top:8px;right:8px}.gallery-close-btn:hover{background:#595959}.gallery-body{flex-shrink:0;justify-content:center;align-items:center;height:40vh;min-height:200px;max-height:500px;padding:12px;display:flex;position:relative}.gallery-image-wrapper{justify-content:center;align-items:center;width:100%;height:100%;display:flex;overflow:hidden}.gallery-image-wrapper img{object-fit:contain;border-radius:8px;width:auto;max-width:100%;height:auto;max-height:100%}.gallery-nav{color:#d6d6d6;cursor:pointer;z-index:1;background:#383838d9;border:none;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:20px;transition:background .2s;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.gallery-nav:hover{background:#595959e6}.gallery-nav-prev{left:12px}.gallery-nav-next{right:12px}.gallery-footer{border-top:1px solid #2e2e2e;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;padding:12px 16px;display:flex}.gallery-footer-left{flex-wrap:wrap;align-items:center;gap:10px;min-width:0;display:flex}.gallery-title{color:#fafafa;white-space:normal;word-break:break-word;overflow-wrap:break-word;font-size:.9rem;font-weight:600;line-height:1.3}.gallery-url{color:#ffdb70;white-space:nowrap;background:#ffdb701a;border-radius:6px;align-items:center;gap:4px;padding:4px 10px;font-size:.82rem;font-weight:500;text-decoration:none;transition:background .2s,color .2s;display:inline-flex}.gallery-url:hover{color:#ffe699;background:#ffdb7033}.gallery-description{color:#a6a6a6;max-height:150px;padding:0 16px 14px;font-size:.82rem;line-height:1.6;overflow-y:auto}.gallery-description p{margin:0 0 4px}.gallery-description p:empty{height:8px;margin:0}.gallery-counter{color:#999;font-size:.85rem;font-weight:500}.gallery-thumbnails{scroll-behavior:smooth;scrollbar-width:none;gap:6px;padding:0 16px 12px;display:flex;overflow-x:auto}.gallery-thumbnails::-webkit-scrollbar{display:none}.gallery-thumb{cursor:pointer;opacity:.5;background:0 0;border:2px solid #0000;border-radius:6px;flex-shrink:0;width:56px;height:40px;padding:0;transition:opacity .2s,border-color .2s;overflow:hidden}.gallery-thumb.active,.gallery-thumb:hover{opacity:1;border-color:#ffdb70}.gallery-thumb img{object-fit:cover;width:100%;height:100%}.gallery-popup-detail{max-width:760px;overflow:hidden auto}.gallery-hero{aspect-ratio:16/8;background:#19191a;border-radius:12px 12px 0 0;flex-shrink:0;position:relative;overflow:hidden}.gallery-hero .gallery-image-wrapper{width:100%;height:100%}.gallery-hero .gallery-image-wrapper img{object-fit:cover;border-radius:0;width:100%;height:100%}.gallery-hero .gallery-counter{color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0000008c;border-radius:20px;padding:2px 8px;font-size:.78rem;position:absolute;bottom:10px;right:14px}.project-detail-body{flex-direction:column;gap:20px;padding:24px 28px 28px;display:flex}.project-detail-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.project-detail-title{color:#ffdb70;flex:1;min-width:0;font-size:1.35rem;font-weight:700;line-height:1.25}.project-detail-link{color:#ffdb70;white-space:nowrap;background:#ffdb701a;border:1px solid #ffdb7033;border-radius:8px;flex-shrink:0;align-items:center;gap:5px;padding:6px 14px;font-size:.82rem;font-weight:500;text-decoration:none;transition:background .2s,border-color .2s;display:inline-flex}.project-detail-link:hover{background:#ffdb702e;border-color:#ffdb7066}.project-detail-desc{color:#a6a6a6;margin:0;font-size:.88rem;line-height:1.65}.project-meta-grid{border:1px solid #333;border-radius:10px;grid-template-columns:repeat(4,1fr);gap:1px;display:grid;overflow:hidden}.project-meta-item{text-align:center;background:#252527;border-right:1px solid #333;flex-direction:column;align-items:center;gap:5px;padding:14px 10px;display:flex}.project-meta-item:last-child{border-right:none}.project-meta-label{color:gray;text-transform:uppercase;letter-spacing:.05em;font-size:.72rem;font-weight:500}.project-meta-value{color:#e6e6e6;font-size:.85rem;font-weight:600;line-height:1.3}.project-ps-grid{grid-template-columns:1fr 1fr;gap:14px;display:grid}.project-ps-card{text-align:center;background:#252527;border:1px solid #333;border-radius:10px;flex-direction:column;align-items:center;gap:10px;padding:18px;display:flex}.project-ps-icon{color:#8c8c8c;font-size:28px;line-height:1}.project-ps-problem .project-ps-label{color:#ed5e5e}.project-ps-solution .project-ps-label{color:#ffdb70}.project-ps-label{letter-spacing:.08em;font-size:.72rem;font-weight:700}.project-ps-card p{color:#a6a6a6;margin:0;font-size:.83rem;line-height:1.6}.project-features{flex-direction:column;gap:10px;display:flex}.project-features-title{color:#ccc;text-transform:uppercase;letter-spacing:.06em;font-size:.82rem;font-weight:600}.project-features-list{flex-direction:column;gap:7px;margin:0;padding:0;list-style:none;display:flex}.project-features-list li{color:#a6a6a6;align-items:flex-start;gap:8px;font-size:.84rem;line-height:1.5;display:flex}.project-features-list li ion-icon{color:#ffdb70;flex-shrink:0;margin-top:2px;font-size:15px}.project-detail-tech{flex-direction:column;gap:10px;display:flex}@media (max-width:600px){.project-meta-grid{grid-template-columns:repeat(2,1fr)}.project-meta-item:nth-child(2){border-right:none}.project-meta-item:first-child,.project-meta-item:nth-child(2){border-bottom:1px solid #333}.project-ps-grid{grid-template-columns:1fr}.project-detail-body{padding:18px 16px 22px}.project-detail-title{font-size:1.1rem}}.hobbies-content{margin-bottom:15px}.hobbies-content .hobbies-title{margin-bottom:20px}.hobby-card{padding:20px}.hobby-header{align-items:center;gap:12px;margin-bottom:18px;display:flex}.hobby-icon{font-size:28px;line-height:1}.hobby-subtitle{color:#8c8c8c;margin-top:2px;font-size:.8rem}.chess-pinned-section{margin-bottom:20px}.chess-pinned-label,.chess-section-label{color:var(--orange-yellow-crayola);text-transform:uppercase;letter-spacing:1px;align-items:center;gap:6px;margin-bottom:10px;font-size:.78rem;font-weight:600;display:flex}.chess-section-label{color:var(--light-gray);margin-top:4px}.chess-pin-badge{color:var(--orange-yellow-crayola);letter-spacing:.3px;background:#ffdb701f;border-radius:50px;margin-bottom:4px;padding:3px 10px;font-size:.68rem;font-weight:600;display:inline-block}.chess-games-list{flex-direction:column;gap:12px;display:flex}.chess-game-item{background:#252527;border:1px solid #333;border-radius:10px;flex-direction:column;gap:10px;padding:14px 16px;transition:border-color .2s,box-shadow .2s;display:flex}.chess-game-item:hover{border-color:#4d4d4d}.chess-game-pinned{background:#28282a;border-color:#ffdb7033}.chess-border-win{border-left:3px solid #2eb85c}.chess-border-loss{border-left:3px solid #c33}.chess-game-players{color:#e6e6e6;flex-wrap:wrap;align-items:center;gap:8px;font-size:.88rem;display:flex}.chess-player{flex-wrap:wrap;align-items:center;gap:6px;min-width:0;display:flex}.chess-piece-icon{font-size:1rem;line-height:1}.chess-piece-white{color:#e6e6e6}.chess-piece-black{color:#666}.chess-flag{object-fit:cover;vertical-align:middle;border-radius:2px;flex-shrink:0;width:20px;height:15px}.chess-avatar{object-fit:cover;border:1px solid #404040;border-radius:50%;flex-shrink:0;width:28px;height:28px}.chess-avatar-placeholder{color:gray;background:#333;justify-content:center;align-items:center;font-size:.75rem;display:inline-flex}.chess-player-name{color:#e6e6e6;overflow-wrap:break-word;word-break:break-word;min-width:0;font-size:.85rem;font-weight:500}.chess-elo{color:#8c8c8c;font-size:.78rem;font-weight:400}.chess-vs{color:#737373;padding:0 2px;font-size:.75rem;font-weight:400}.chess-title-badge{color:#fff;vertical-align:middle;letter-spacing:.5px;background:#cf8217;border-radius:3px;margin-right:4px;padding:1px 5px;font-size:.62rem;font-weight:700;display:inline-block}.chess-game-meta{color:#8c8c8c;flex-wrap:wrap;align-items:center;gap:8px;font-size:.78rem;display:flex;overflow:hidden}.chess-result{text-transform:uppercase;letter-spacing:.5px;border-radius:4px;padding:2px 8px;font-size:.72rem;font-weight:600}.chess-result-win{color:#47d175;background:#29a35233}.chess-result-loss{color:#d65c5c;background:#a3292933}.chess-result-draw{color:#a6a6a6;background:#80808033}.chess-game-footer{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;display:flex}.chess-termination{color:gray;font-size:.78rem;font-style:italic}.chess-view-btn{color:#ffdb70;white-space:nowrap;background:#ffdb701a;border-radius:6px;align-items:center;gap:4px;padding:4px 10px;font-size:.8rem;font-weight:500;text-decoration:none;transition:background .2s,color .2s;display:inline-flex}.chess-view-btn:hover{color:#ffe699;background:#ffdb7033}.pagination{border-top:1px solid #2e2e2e;justify-content:center;align-items:center;gap:6px;margin-top:18px;padding-top:14px;display:flex}.page-btn{color:#999;cursor:pointer;background:#28282a;border:1px solid #383838;border-radius:6px;justify-content:center;align-items:center;min-width:32px;height:32px;padding:0 8px;font-size:.8rem;font-weight:500;transition:all .2s;display:inline-flex}.page-btn:hover:not(:disabled){color:#d9d9d9;background:#323234;border-color:#4d4d4d}.page-btn.active{color:var(--orange-yellow-crayola);background:#ffdb7026;border-color:#ffdb704d;font-weight:600}.page-btn:disabled{opacity:.3;cursor:not-allowed}.chess-all-section{margin-top:4px}
