.projects{padding:6rem 0 2rem;background-color:transparent;scroll-margin-top:80px}.projects-page-wrapper{background:linear-gradient(135deg,rgba(0,0,0,.8),rgba(0,50,100,.6));min-height:100vh;position:relative}.projects-page-wrapper:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background:url(/technology-looped-background.mp4) 50%/cover;opacity:.1;z-index:-1;pointer-events:none}.projects h2{text-align:center;margin-bottom:2rem;color:var(--text)}.projects-subtitle{font-size:1.1rem;line-height:1.6}.projects-subtitle,.section-description{text-align:center;color:var(--text-secondary);max-width:600px;margin:0 auto 3rem}.projects-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem;max-width:1000px;margin:0 auto}@media (max-width:1200px){.projects-grid{grid-template-columns:repeat(2,1fr);gap:1.5rem;max-width:900px}.project-image{height:220px}.project-card h3{font-size:1.3rem}.project-card p{font-size:.95rem}}@media (max-width:1024px){.projects-grid{grid-template-columns:repeat(2,1fr);gap:1.2rem;max-width:800px}.project-image{height:200px}.project-card{padding:1.2rem}.project-card h3{font-size:1.2rem}.project-card p{font-size:.9rem}.tech-tag{font-size:.75rem;padding:.2rem .5rem}}@media (max-width:768px){.projects{padding:5rem 0 1rem}.projects h2{font-size:1.8rem;margin-bottom:1.5rem}.projects-subtitle{font-size:1rem;margin-bottom:2rem;padding:0 1rem}.projects-grid{grid-template-columns:1fr;gap:1.5rem;padding:0 1rem}.project-card{padding:1.5rem}.project-image{height:200px;margin-bottom:.8rem}.project-card h3{font-size:1.2rem;margin-bottom:.8rem}.project-card p{font-size:.9rem;line-height:1.5}.project-card p,.project-technologies{margin-bottom:1.2rem}.project-technologies .tech-tag{white-space:nowrap}.tech-tag{font-size:.6rem;padding:.15rem .4rem;margin:.05rem}}@media (max-width:480px){.projects{padding:4.5rem 0 .5rem}.projects h2{font-size:1.6rem;margin-bottom:1rem}.projects-subtitle{font-size:.9rem;margin-bottom:1.5rem;padding:0 .5rem}.projects-grid{gap:1rem;padding:0 .5rem}.project-card{padding:1rem}.project-image{height:180px;margin-bottom:.6rem}.project-card h3{font-size:1.1rem;margin-bottom:.6rem}.project-card p{font-size:.85rem;line-height:1.4}.project-card p,.project-technologies{margin-bottom:1rem}.project-technologies .tech-tag{white-space:nowrap}.tech-tag{font-size:.55rem;padding:.1rem .3rem;margin:.03rem}}.project-card{border:none;border-radius:12px;transition:all .4s cubic-bezier(.25,.46,.45,.94);will-change:transform,box-shadow,background;position:relative;overflow:hidden;display:flex;flex-direction:column;height:100%;padding:1.5rem}.project-card,.project-card:hover{background:transparent;backdrop-filter:none;box-shadow:none}.project-card:hover{transform:none;border:none;outline:none}.dark .project-card,.dark .project-card:hover{background:transparent;backdrop-filter:none;border:none;box-shadow:none}.dark .project-card:hover{transform:none;outline:none}.project-card i{transition:none;transform:none}.project-card:hover i{transform:none}.project-card h3{transition:color .3s ease}.project-card:hover h3{color:var(--primary)}.project-card p{color:var(--text-secondary);line-height:1.6;margin-bottom:1.5rem;flex-grow:1;min-height:4.5rem;overflow:hidden;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical}.project-technologies{margin-bottom:1.5rem;margin-top:auto;position:relative}.project-technologies h4{margin-bottom:.8rem;color:var(--text);font-size:1rem;font-weight:600}.tech-tags{display:flex;flex-wrap:nowrap;gap:.2rem;overflow-x:auto;padding-bottom:.2rem;scrollbar-width:thin;scrollbar-color:rgba(0,122,255,.3) transparent}.tech-tags::-webkit-scrollbar{height:4px}.tech-tags::-webkit-scrollbar-track{background:transparent}.tech-tags::-webkit-scrollbar-thumb{background:rgba(0,122,255,.3);border-radius:2px}.tech-tag{background-color:rgba(0,122,255,.1);color:var(--primary);padding:.15rem .4rem;border-radius:10px;font-size:.7rem;border:1px solid rgba(0,122,255,.2);display:inline-block;margin:.05rem .1rem;transition:all .3s ease;white-space:nowrap;flex-shrink:0}.tech-tag:hover{background-color:var(--primary);color:white;transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,122,255,.3)}.project-links{display:flex;gap:1rem;margin-top:auto}.project-link{flex:1;padding:.8rem 1.2rem;background:linear-gradient(45deg,var(--primary),#00c6ff);color:white!important;text-decoration:none;border-radius:8px;font-weight:600;font-size:.9rem;text-align:center;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 15px rgba(0,122,255,.3);position:relative;overflow:hidden}.project-link:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s;z-index:-1}.project-link:hover:before{left:100%}.project-link:hover{background:linear-gradient(45deg,#0056b3,#00c6ff);box-shadow:0 8px 25px rgba(0,122,255,.4);color:white;transform:none}.project-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.85);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .5s cubic-bezier(.4,0,.2,1);filter:none}.project-overlay.active{opacity:1}.no-tab,.no-tab:focus{outline:none}.projects ul{list-style:none;padding:0}.projects li{margin-bottom:1rem}.projects a{color:var(--text);text-decoration:none;transition:var(--transition)}.projects a:hover{color:var(--primary)}.project-card .btn{display:inline-block;padding:.8rem 1.5rem;background:var(--primary);color:white!important;text-decoration:none;border-radius:8px;font-weight:500;transition:all .5s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;z-index:1}.project-card .btn:hover{transform:translateY(-2px);box-shadow:0 5px 15px rgba(0,122,255,.3);background:linear-gradient(45deg,var(--primary),#4a90e2);color:white!important}.project-card .btn:active{transform:translateY(0)}.project-card .btn:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(45deg,var(--primary),#4a90e2);opacity:0;transition:opacity .5s cubic-bezier(.4,0,.2,1);z-index:-1}.project-card .btn:hover:before{opacity:1}.project-card-link{display:block;text-decoration:none;color:inherit;transition:transform .3s ease,box-shadow .3s ease}.project-card-link:hover{text-decoration:none;color:inherit;transform:none}.project-card-link:hover .project-card{box-shadow:none}.project-image{position:relative;width:100%;height:250px;overflow:hidden;border-radius:8px;margin-bottom:.8rem}.project-image img{width:100%;height:100%;object-fit:contain;object-position:center;transition:transform .3s ease;transform:scale(1.1)}.project-content{margin-top:.2rem}.project-card-link:hover .project-image img{transform:scale(1.15)}.dark .tech-tag{background-color:rgba(0,122,255,.25);color:#fff;border-color:rgba(0,122,255,.5);font-weight:600}.dark .tech-tag:hover{background-color:var(--primary);color:#fff;box-shadow:0 4px 12px rgba(0,122,255,.5)}.image-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,rgba(0,0,0,.1),rgba(0,50,100,.1));border-radius:8px;position:relative;overflow:hidden}.loading-spinner{width:40px;height:40px;border:3px solid rgba(0,122,255,.2);border-top:3px solid var(--primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.project-image img{opacity:0;animation:fadeInImage .5s ease-in-out forwards}@keyframes fadeInImage{0%{opacity:0;transform:scale(1.05)}to{opacity:1;transform:scale(1.1)}}.project-image{background:linear-gradient(135deg,rgba(0,0,0,.05),rgba(0,50,100,.05));transition:background .3s ease}.project-image img{transition:opacity .3s ease,transform .3s ease}.dark .image-placeholder{background:linear-gradient(135deg,rgba(255,255,255,.05),rgba(0,50,100,.1))}.dark .loading-spinner{border-color:rgba(255,255,255,.2);border-top-color:var(--primary)}