.projects-page{--projects-primary:#0ea5e9;--projects-primary-hover:#0284c7;--projects-bg:#ffffff;--projects-container-bg:transparent;--projects-card-bg:#ffffff;--projects-card-border:rgba(226, 232, 240, 1);--projects-card-shadow:0 1px 2px 0 rgba(0, 0, 0, 0.05);--projects-card-shadow-hover:0 4px 6px -1px rgba(0, 0, 0, 0.05);--projects-text-title:#0f172a;--projects-text-body:#475569;--projects-text-muted:#64748b;--projects-filter-bg:rgba(248, 250, 252, 0.8);--projects-filter-border:rgba(226, 232, 240, 0.5);--projects-img-bg:#f1f5f9}[data-scheme=dark] .projects-page,[data-scheme=dark] body.projects-page{--projects-bg:#09090b;--projects-card-bg:#27272a;--projects-card-border:rgba(63, 63, 70, 0.5);--projects-card-shadow:none;--projects-card-shadow-hover:0 4px 12px rgba(0, 0, 0, 0.3);--projects-text-title:#fafafa;--projects-text-body:#e4e4e7;--projects-text-muted:#a1a1aa;--projects-filter-bg:rgba(63, 63, 70, 0.8);--projects-filter-border:rgba(82, 82, 91, 0.5);--projects-img-bg:#27272a}.projects-container{max-width:1200px;margin:0 auto;padding:2rem 1.5rem;width:100%}.projects-header{text-align:center;margin-bottom:4rem;animation:fadeInDown .8s cubic-bezier(.16,1,.3,1)}.projects-title{font-size:4rem;font-weight:800;color:var(--projects-text-title);margin-bottom:1.5rem;line-height:1.1;letter-spacing:-.02em}.projects-description{font-size:1.5rem;color:var(--projects-text-body);max-width:800px;margin:0 auto;line-height:1.6}.projects-filter{margin-bottom:3.5rem;background:var(--projects-filter-bg);padding:1.25rem 2rem;border-radius:1.5rem;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--projects-filter-border);transition:all .3s ease}.filter-group{display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap}.filter-label{font-weight:700;color:var(--projects-text-body);font-size:1rem;text-transform:uppercase;letter-spacing:.1em}.tech-filter-buttons{display:flex;flex-wrap:wrap;gap:.875rem}.filter-btn{padding:.75rem 1.5rem;border-radius:1.25rem;border:1px solid var(--projects-card-border);background:var(--projects-bg);color:var(--projects-text-body);font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1)}.filter-btn:hover{border-color:var(--projects-primary);color:var(--projects-primary);transform:translateY(-2px)}.filter-btn.active{background:var(--projects-primary);color:#fff;border-color:var(--projects-primary);box-shadow:0 8px 16px -4px rgba(14,165,233,.3)}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:2.5rem;margin-bottom:5rem}.project-card{background:var(--projects-card-bg);border-radius:2.5rem;overflow:hidden;border:1px solid var(--projects-card-border);box-shadow:var(--projects-card-shadow);transition:all .6s cubic-bezier(.16,1,.3,1);position:relative;opacity:0;transform:translateY(10px);animation:fadeInUp .5s ease-out forwards}.project-card:hover{transform:translateY(-4px);box-shadow:var(--projects-card-shadow-hover);border-color:var(--projects-primary)}.project-card-inner{display:flex;flex-direction:column;height:100%}.project-image-container{width:100%;padding:1.25rem 1.25rem 0;overflow:hidden}.project-image-link{display:block;border-radius:2.25rem;overflow:hidden;aspect-ratio:16/10;width:100%;height:100%;background:var(--projects-img-bg)}.project-image-link img{width:100%;height:100%;display:block;object-fit:cover;transition:transform 1s cubic-bezier(.16,1,.3,1)}.project-card:hover .project-image-link img{transform:scale(1.1)}.project-content{padding:1.75rem 2rem 2.25rem;display:flex;flex-direction:column;flex:1}.project-type-label{font-size:1rem;font-weight:800;color:var(--projects-primary);letter-spacing:.15em;margin-bottom:.75rem;text-transform:uppercase}.project-header-row{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.project-title{margin:0;font-size:2rem;font-weight:600;color:var(--projects-text-title);flex:1;line-height:1.15;letter-spacing:-.02em}.project-title a{color:inherit;text-decoration:none;transition:color .3s ease}.project-title a:hover{color:var(--projects-primary)}.project-github-icon{display:flex;padding:.5rem;border:1px solid var(--projects-card-border);border-radius:1rem;color:var(--projects-text-muted);transition:all .3s cubic-bezier(.4,0,.2,1);margin-left:1.5rem;background:var(--projects-bg)}.project-github-icon:hover{border-color:var(--projects-primary);color:var(--projects-primary);background:var(--projects-filter-bg);transform:scale(1.1)}.project-tags{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:1.5rem}.project-tag-badge{font-size:.875rem;font-weight:700;text-transform:uppercase;padding:.375rem 1rem;border-radius:.75rem;letter-spacing:.05em;border:1px solid transparent}.project-tag-badge:nth-child(3n+1){background:rgba(34,197,94,.1);color:#22c55e;border-color:rgba(34,197,94,.2)}.project-tag-badge:nth-child(3n+2){background:rgba(59,130,246,.1);color:#3b82f6;border-color:rgba(59,130,246,.2)}.project-tag-badge:nth-child(3n+3){background:rgba(245,158,11,.1);color:#f59e0b;border-color:rgba(245,158,11,.2)}.project-description{font-size:1.125rem;line-height:1.6;color:var(--projects-text-body);margin-bottom:2rem;flex:1;display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.project-footer{margin-top:auto}.read-more-btn{display:inline-block;padding:.75rem 2rem;border:2px solid var(--projects-primary);border-radius:1.125rem;color:var(--projects-primary);font-weight:800;text-decoration:none;transition:all .4s cubic-bezier(.16,1,.3,1);font-size:.9375rem;letter-spacing:.02em}.read-more-btn:hover{background:var(--projects-primary);color:#fff;box-shadow:0 12px 24px -6px rgba(14,165,233,.4);transform:translateY(-2px)}@keyframes fadeInUp{from{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{from{opacity:0;transform:translateY(-40px)}to{opacity:1;transform:translateY(0)}}.hidden{display:none!important}[data-scheme=dark] .project-github-icon{background:#1e293b}@media(max-width:768px){.projects-grid{grid-template-columns:1fr;gap:2rem}.projects-title{font-size:2.5rem}.project-card{border-radius:2rem}}@media(min-width:1200px){.projects-grid{grid-template-columns:repeat(3,1fr)}}