.projects-page{padding:6rem 2rem}@media(max-width:768px){.projects-page{padding:4rem 1rem}}@media(max-width:480px){.projects-page{padding:3rem 1rem}}#projects-container .project-wrapper,#projects-container h2{margin-bottom:2rem}#projects-container .project-wrapper hr{margin:1rem 0}.project-article{background:rgba(29,29,29,.8);border-radius:8px;padding:1.5rem;transition:all .3s ease;position:relative;overflow:hidden;height:100%;min-height:350px;width:100%}.project-article:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,#fa5252,#dd2476);opacity:0;transition:opacity .3s ease}.project-article:hover:before{opacity:1}.project-article .project-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.project-article .project-header h3{font-size:1.5rem;color:#fff;margin:0;font-family:JetBrains Mono,monospace}.project-article .project-header .project-links{display:flex;gap:1rem}.project-article .project-header .project-links .project-link{color:#a6a6a6;font-size:1.25rem;transition:all .3s ease}.project-article .project-header .project-links .project-link:hover{color:#dd2476;transform:translateY(-2px)}.project-article .description{color:#a6a6a6;line-height:1.6;margin-bottom:1.5rem;font-size:.95rem}.project-article .technologies{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}.project-article .technologies .tech-tag{background:rgba(221,36,118,.1);color:#dd2476;padding:.25rem .75rem;border-radius:4px;font-size:.85rem;font-family:JetBrains Mono,monospace;transition:all .3s ease}.project-article .technologies .tech-tag:hover{background:rgba(221,36,118,.2);transform:translateY(-2px)}.project-article .project-tabs{display:flex;gap:1rem;margin-bottom:1.5rem;border-bottom:1px solid hsla(0,0%,65%,.2)}.project-article .project-tabs button{background:none;border:none;color:#a6a6a6;padding:.5rem 1rem;cursor:pointer;font-family:JetBrains Mono,monospace;font-size:.9rem;position:relative;transition:all .3s ease}.project-article .project-tabs button:after{content:"";position:absolute;bottom:-1px;left:0;width:100%;height:2px;background:linear-gradient(90deg,#fa5252,#dd2476);transform:scaleX(0);transition:transform .3s ease}.project-article .project-tabs button:hover{color:#fff}.project-article .project-tabs button.active{color:#dd2476}.project-article .project-tabs button.active:after{transform:scaleX(1)}.project-article .tab-content{min-height:200px}.project-article .tab-content ul{list-style:none;padding:0;margin:0}.project-article .tab-content ul li{color:#a6a6a6;margin-bottom:.75rem;padding-left:1.5rem;position:relative;font-size:.9rem}.project-article .tab-content ul li:before{content:">";position:absolute;left:0;color:#dd2476;font-family:JetBrains Mono,monospace}.project-article .tab-content .challenges-solutions{display:flex;flex-direction:column;gap:1.5rem}.project-article .tab-content .challenges-solutions .challenge-solution-pair{border-left:2px solid #dd2476;padding-left:1rem}.project-article .tab-content .challenges-solutions .challenge-solution-pair h5{color:#dd2476;margin:0 0 .5rem;font-family:JetBrains Mono,monospace;font-size:.9rem}.project-article .tab-content .challenges-solutions .challenge-solution-pair p{color:#a6a6a6;margin:0;font-size:.9rem}.project-article.featured{background:rgba(29,29,29,.9);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:2rem;min-height:400px}@media(min-width:1024px){.project-article.featured{width:100%;margin:0 auto}}@media(min-width:1200px){.project-article.featured{max-width:1000px}}@media(max-width:768px){.project-article{padding:1rem;min-height:300px;width:100%}.project-article.featured{padding:1.5rem;min-height:350px}}.projects-section{padding:6rem 0}@media(max-width:768px){.projects-section{padding:4rem 1rem}}@media(max-width:480px){.projects-section{padding:3rem 1rem}}.projects-section .section-header{text-align:center;margin-bottom:4rem}@media(max-width:480px){.projects-section .section-header{margin-bottom:2rem}}.projects-section .section-header h2{font-size:2.5rem;margin-bottom:1rem}@media(max-width:480px){.projects-section .section-header h2{font-size:2rem}}.projects-section .projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));grid-gap:2rem;gap:2rem}@media(max-width:480px){.projects-section .projects-grid{grid-template-columns:1fr;gap:1.5rem}}.projects-section .projects-filters{max-width:1200px;margin:0 auto 3rem;display:flex;flex-direction:column;gap:1.5rem}.projects-section .projects-filters .search-input{padding:1rem;border:1px solid rgba(221,36,118,.3);background:rgba(29,29,29,.7);border-radius:8px;color:#fff;font-size:1rem;width:100%;transition:all .3s cubic-bezier(.4,0,.2,1)}.projects-section .projects-filters .search-input:focus{border-color:#dd2476;box-shadow:0 0 0 2px rgba(221,36,118,.2);outline:none}.projects-section .projects-filters .filter-buttons{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center}.projects-section .projects-filters .filter-buttons .filter-btn{padding:.8rem 1.8rem;background:rgba(29,29,29,.5);color:#fff;border-radius:10px;cursor:pointer;font-family:JetBrains Mono,monospace;font-size:.95rem;letter-spacing:.5px;transition:all .3s ease;position:relative;overflow:hidden;border:none}.projects-section .projects-filters .filter-buttons .filter-btn[data-category=all]{border:2px solid rgba(121,40,202,.3)}.projects-section .projects-filters .filter-buttons .filter-btn[data-category=all]:hover{border-color:rgba(121,40,202,.8);box-shadow:0 5px 15px rgba(121,40,202,.2);background:rgba(121,40,202,.1)}.projects-section .projects-filters .filter-buttons .filter-btn[data-category=all].active{background:#7928ca;border-color:#7928ca;color:#fff;box-shadow:0 5px 15px rgba(121,40,202,.3)}.projects-section .projects-filters .filter-buttons .filter-btn[data-category=all].active:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(121,40,202,.4)}.projects-section .projects-filters .filter-buttons .filter-btn[data-category=react]{border:2px solid rgba(97,218,251,.3)}.projects-section .projects-filters .filter-buttons .filter-btn[data-category=react]:hover{border-color:rgba(97,218,251,.8);box-shadow:0 5px 15px rgba(97,218,251,.2);background:rgba(97,218,251,.1)}.projects-section .projects-filters .filter-buttons .filter-btn[data-category=react].active{background:#61dafb;border-color:#61dafb;color:#000;box-shadow:0 5px 15px rgba(97,218,251,.3)}.projects-section .projects-filters .filter-buttons .filter-btn[data-category=react].active:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(97,218,251,.4)}.projects-section .projects-filters .filter-buttons .filter-btn[data-category=next]{border:2px solid rgba(0,0,0,.3)}.projects-section .projects-filters .filter-buttons .filter-btn[data-category=next]:hover{border-color:rgba(0,0,0,.8);box-shadow:0 5px 15px rgba(0,0,0,.2);background:rgba(0,0,0,.1)}.projects-section .projects-filters .filter-buttons .filter-btn[data-category=next].active{background:#000;border-color:#000;color:#fff;box-shadow:0 5px 15px rgba(0,0,0,.3)}.projects-section .projects-filters .filter-buttons .filter-btn[data-category=next].active:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(0,0,0,.4)}.projects-section .projects-filters .filter-buttons .filter-btn[data-category=vue]{border:2px solid rgba(66,184,131,.3)}.projects-section .projects-filters .filter-buttons .filter-btn[data-category=vue]:hover{border-color:rgba(66,184,131,.8);box-shadow:0 5px 15px rgba(66,184,131,.2);background:rgba(66,184,131,.1)}.projects-section .projects-filters .filter-buttons .filter-btn[data-category=vue].active{background:#42b883;border-color:#42b883;color:#fff;box-shadow:0 5px 15px rgba(66,184,131,.3)}.projects-section .projects-filters .filter-buttons .filter-btn[data-category=vue].active:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(66,184,131,.4)}.projects-section .projects-filters .filter-buttons .filter-btn[data-category=angular]{border:2px solid rgba(221,0,49,.3)}.projects-section .projects-filters .filter-buttons .filter-btn[data-category=angular]:hover{border-color:rgba(221,0,49,.8);box-shadow:0 5px 15px rgba(221,0,49,.2);background:rgba(221,0,49,.1)}.projects-section .projects-filters .filter-buttons .filter-btn[data-category=angular].active{background:#dd0031;border-color:#dd0031;color:#fff;box-shadow:0 5px 15px rgba(221,0,49,.3)}.projects-section .projects-filters .filter-buttons .filter-btn[data-category=angular].active:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(221,0,49,.4)}.projects-section .projects-filters .filter-buttons .filter-btn[data-category=javascript]{border:2px solid rgba(247,223,30,.3)}.projects-section .projects-filters .filter-buttons .filter-btn[data-category=javascript]:hover{border-color:rgba(247,223,30,.8);box-shadow:0 5px 15px rgba(247,223,30,.2);background:rgba(247,223,30,.1)}.projects-section .projects-filters .filter-buttons .filter-btn[data-category=javascript].active{background:#f7df1e;border-color:#f7df1e;color:#000;box-shadow:0 5px 15px rgba(247,223,30,.3)}.projects-section .projects-filters .filter-buttons .filter-btn[data-category=javascript].active:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(247,223,30,.4)}.projects-section .projects-filters .filter-buttons .filter-btn[data-category=typescript]{border:2px solid rgba(49,120,198,.3)}.projects-section .projects-filters .filter-buttons .filter-btn[data-category=typescript]:hover{border-color:rgba(49,120,198,.8);box-shadow:0 5px 15px rgba(49,120,198,.2);background:rgba(49,120,198,.1)}.projects-section .projects-filters .filter-buttons .filter-btn[data-category=typescript].active{background:#3178c6;border-color:#3178c6;color:#fff;box-shadow:0 5px 15px rgba(49,120,198,.3)}.projects-section .projects-filters .filter-buttons .filter-btn[data-category=typescript].active:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(49,120,198,.4)}.projects-section .projects-filters .filter-buttons .filter-btn[data-category=css]{border:2px solid rgba(21,114,182,.3)}.projects-section .projects-filters .filter-buttons .filter-btn[data-category=css]:hover{border-color:rgba(21,114,182,.8);box-shadow:0 5px 15px rgba(21,114,182,.2);background:rgba(21,114,182,.1)}.projects-section .projects-filters .filter-buttons .filter-btn[data-category=css].active{background:#1572b6;border-color:#1572b6;color:#fff;box-shadow:0 5px 15px rgba(21,114,182,.3)}.projects-section .projects-filters .filter-buttons .filter-btn[data-category=css].active:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(21,114,182,.4)}.projects-section .projects-filters .filter-buttons .filter-btn[data-category=tailwind]{border:2px solid rgba(56,178,172,.3)}.projects-section .projects-filters .filter-buttons .filter-btn[data-category=tailwind]:hover{border-color:rgba(56,178,172,.8);box-shadow:0 5px 15px rgba(56,178,172,.2);background:rgba(56,178,172,.1)}.projects-section .projects-filters .filter-buttons .filter-btn[data-category=tailwind].active{background:#38b2ac;border-color:#38b2ac;color:#fff;box-shadow:0 5px 15px rgba(56,178,172,.3)}.projects-section .projects-filters .filter-buttons .filter-btn[data-category=tailwind].active:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(56,178,172,.4)}.projects-section .projects-filters .filter-buttons .filter-btn[data-category=sass]{border:2px solid rgba(204,102,153,.3)}.projects-section .projects-filters .filter-buttons .filter-btn[data-category=sass]:hover{border-color:rgba(204,102,153,.8);box-shadow:0 5px 15px rgba(204,102,153,.2);background:rgba(204,102,153,.1)}.projects-section .projects-filters .filter-buttons .filter-btn[data-category=sass].active{background:#c69;border-color:#c69;color:#000;box-shadow:0 5px 15px rgba(204,102,153,.3)}.projects-section .projects-filters .filter-buttons .filter-btn[data-category=sass].active:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(204,102,153,.4)}.projects-section .projects-filters .filter-buttons .filter-btn[data-category=node]{border:2px solid rgba(51,153,51,.3)}.projects-section .projects-filters .filter-buttons .filter-btn[data-category=node]:hover{border-color:rgba(51,153,51,.8);box-shadow:0 5px 15px rgba(51,153,51,.2);background:rgba(51,153,51,.1)}.projects-section .projects-filters .filter-buttons .filter-btn[data-category=node].active{background:#393;border-color:#393;color:#fff;box-shadow:0 5px 15px rgba(51,153,51,.3)}.projects-section .projects-filters .filter-buttons .filter-btn[data-category=node].active:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(51,153,51,.4)}.projects-section .projects-filters .filter-buttons .filter-btn[data-category=python]{border:2px solid rgba(55,118,171,.3)}.projects-section .projects-filters .filter-buttons .filter-btn[data-category=python]:hover{border-color:rgba(55,118,171,.8);box-shadow:0 5px 15px rgba(55,118,171,.2);background:rgba(55,118,171,.1)}.projects-section .projects-filters .filter-buttons .filter-btn[data-category=python].active{background:#3776ab;border-color:#3776ab;color:#fff;box-shadow:0 5px 15px rgba(55,118,171,.3)}.projects-section .projects-filters .filter-buttons .filter-btn[data-category=python].active:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(55,118,171,.4)}.projects-section .projects-filters .filter-buttons .filter-btn[data-category=firebase]{border:2px solid rgba(255,202,40,.3)}.projects-section .projects-filters .filter-buttons .filter-btn[data-category=firebase]:hover{border-color:rgba(255,202,40,.8);box-shadow:0 5px 15px rgba(255,202,40,.2);background:rgba(255,202,40,.1)}.projects-section .projects-filters .filter-buttons .filter-btn[data-category=firebase].active{background:#ffca28;border-color:#ffca28;color:#000;box-shadow:0 5px 15px rgba(255,202,40,.3)}.projects-section .projects-filters .filter-buttons .filter-btn[data-category=firebase].active:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(255,202,40,.4)}.projects-section .projects-filters .filter-buttons .filter-btn[data-category=mongodb]{border:2px solid rgba(71,162,72,.3)}.projects-section .projects-filters .filter-buttons .filter-btn[data-category=mongodb]:hover{border-color:rgba(71,162,72,.8);box-shadow:0 5px 15px rgba(71,162,72,.2);background:rgba(71,162,72,.1)}.projects-section .projects-filters .filter-buttons .filter-btn[data-category=mongodb].active{background:#47a248;border-color:#47a248;color:#fff;box-shadow:0 5px 15px rgba(71,162,72,.3)}.projects-section .projects-filters .filter-buttons .filter-btn[data-category=mongodb].active:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(71,162,72,.4)}.projects-section .projects-filters .filter-buttons .filter-btn:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:0;height:0;background:hsla(0,0%,100%,.1);border-radius:50%;transition:width .6s ease,height .6s ease}.projects-section .projects-filters .filter-buttons .filter-btn:hover{transform:translateY(-2px)}.projects-section .projects-filters .filter-buttons .filter-btn:hover:before{width:200px;height:200px}.projects-section .projects-filters .filter-buttons .filter-btn:after{content:"";position:absolute;inset:-2px;border-radius:inherit;background:linear-gradient(90deg,#fa5252,#dd2476);opacity:0;transition:opacity .3s ease;z-index:-1}.projects-section .projects-filters .filter-buttons .filter-btn:hover:after{opacity:.5}@keyframes buttonEnter{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.filter-buttons .filter-btn{animation:buttonEnter .3s ease forwards}.filter-buttons .filter-btn:first-child{animation-delay:.05s}.filter-buttons .filter-btn:nth-child(2){animation-delay:.1s}.filter-buttons .filter-btn:nth-child(3){animation-delay:.15s}.filter-buttons .filter-btn:nth-child(4){animation-delay:.2s}.filter-buttons .filter-btn:nth-child(5){animation-delay:.25s}.filter-buttons .filter-btn:nth-child(6){animation-delay:.3s}.filter-buttons .filter-btn:nth-child(7){animation-delay:.35s}.filter-buttons .filter-btn:nth-child(8){animation-delay:.4s}.filter-buttons .filter-btn:nth-child(9){animation-delay:.45s}.filter-buttons .filter-btn:nth-child(10){animation-delay:.5s}@keyframes glitch-anim{0%{clip:rect(31px,9999px,94px,0)}4.166666666666666%{clip:rect(91px,9999px,43px,0)}8.333333333333332%{clip:rect(85px,9999px,29px,0)}12.5%{clip:rect(83px,9999px,40px,0)}16.666666666666664%{clip:rect(61px,9999px,56px,0)}20.833333333333336%{clip:rect(5px,9999px,29px,0)}25%{clip:rect(47px,9999px,31px,0)}29.166666666666668%{clip:rect(47px,9999px,90px,0)}33.33333333333333%{clip:rect(17px,9999px,98px,0)}37.5%{clip:rect(74px,9999px,50px,0)}41.66666666666667%{clip:rect(93px,9999px,74px,0)}45.83333333333333%{clip:rect(24px,9999px,91px,0)}50%{clip:rect(57px,9999px,70px,0)}54.166666666666664%{clip:rect(86px,9999px,29px,0)}58.333333333333336%{clip:rect(25px,9999px,55px,0)}62.5%{clip:rect(33px,9999px,91px,0)}66.66666666666666%{clip:rect(25px,9999px,43px,0)}70.83333333333334%{clip:rect(76px,9999px,98px,0)}75%{clip:rect(85px,9999px,29px,0)}79.16666666666666%{clip:rect(48px,9999px,35px,0)}83.33333333333334%{clip:rect(13px,9999px,74px,0)}87.5%{clip:rect(45px,9999px,55px,0)}91.66666666666666%{clip:rect(86px,9999px,29px,0)}95.83333333333334%{clip:rect(81px,9999px,98px,0)}to{clip:rect(68px,9999px,50px,0)}}@keyframes glitch-anim2{6.666666666666667%{clip:rect(13px,9999px,76px,0)}10%{clip:rect(89px,9999px,66px,0)}13.333333333333334%{clip:rect(65px,9999px,13px,0)}16.666666666666664%{clip:rect(75px,9999px,42px,0)}20%{clip:rect(73px,9999px,78px,0)}23.333333333333332%{clip:rect(89px,9999px,11px,0)}26.666666666666668%{clip:rect(47px,9999px,40px,0)}30%{clip:rect(28px,9999px,18px,0)}33.33333333333333%{clip:rect(54px,9999px,81px,0)}36.666666666666664%{clip:rect(23px,9999px,92px,0)}40%{clip:rect(45px,9999px,26px,0)}43.333333333333336%{clip:rect(80px,9999px,74px,0)}46.666666666666664%{clip:rect(90px,9999px,24px,0)}50%{clip:rect(89px,9999px,80px,0)}53.333333333333336%{clip:rect(88px,9999px,27px,0)}56.666666666666664%{clip:rect(11px,9999px,86px,0)}60%{clip:rect(62px,9999px,33px,0)}63.33333333333333%{clip:rect(19px,9999px,94px,0)}66.66666666666666%{clip:rect(67px,9999px,48px,0)}70%{clip:rect(94px,9999px,44px,0)}73.33333333333333%{clip:rect(41px,9999px,23px,0)}76.66666666666667%{clip:rect(83px,9999px,35px,0)}80%{clip:rect(37px,9999px,29px,0)}83.33333333333334%{clip:rect(16px,9999px,48px,0)}86.66666666666667%{clip:rect(52px,9999px,27px,0)}90%{clip:rect(62px,9999px,46px,0)}93.33333333333333%{clip:rect(46px,9999px,33px,0)}96.66666666666667%{clip:rect(83px,9999px,96px,0)}to{clip:rect(73px,9999px,59px,0)}}@media(max-width:768px){.projects-section{padding:4rem 1rem}.section-header h2{font-size:2rem}.projects-filters .filter-buttons .filter-btn{padding:.5rem 1rem;font-size:.9rem}}