.projects-section{padding:var(--spacing-2xl)0;position:relative}.projects-grid .project-card{opacity:0;animation:fadeInUp var(--transition-slow)ease-out forwards;transform:translateY(20px)}.projects-grid .project-card:first-child{animation-delay:.1s}.projects-grid .project-card:nth-child(2){animation-delay:.2s}.projects-grid .project-card:nth-child(3){animation-delay:.3s}.projects-grid .project-card:nth-child(4){animation-delay:.4s}.projects-grid .project-card:nth-child(5){animation-delay:.5s}.projects-grid .project-card:nth-child(6){animation-delay:.6s}@keyframes fadeInUp{to{opacity:1;transform:translateY(0)}}@media (prefers-reduced-motion:reduce){.projects-grid .project-card{opacity:1;animation:none;transform:none}.category-title:after{animation:none;transform:scaleX(1)}}.projects-category{margin-bottom:var(--spacing-2xl);position:relative}.projects-category:last-child{margin-bottom:0}.category-title{font-size:var(--font-size-xl);color:var(--color-text-primary);margin-bottom:var(--spacing-lg);font-weight:var(--font-weight-bold);letter-spacing:-.02em;display:inline-block;position:relative}.category-title:after{content:"";background:linear-gradient(90deg,var(--color-accent-primary),var(--color-accent-secondary));border-radius:var(--radius-full);transform-origin:0;width:100%;height:3px;animation:slideIn var(--transition-slow)ease-out forwards;position:absolute;bottom:-8px;left:0;transform:scaleX(0)}@keyframes slideIn{to{transform:scaleX(1)}}.projects-grid{gap:var(--spacing-xl);width:100%;margin-top:var(--spacing-lg);grid-template-columns:repeat(auto-fill,minmax(380px,1fr));display:grid;position:relative}.glass-card-link{color:inherit;transition:all var(--transition-normal)cubic-bezier(.4,0,.2,1);text-decoration:none;display:block;position:relative}.glass-card-link:hover{transform:translateY(-8px)}.glass-card-link .glass-card{cursor:pointer}.project-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--radius-lg);cursor:pointer;background:linear-gradient(135deg,#1e293bf2 0%,#1e293bd9 100%);border:1px solid #3b82f626;flex-direction:column;height:100%;transition:all .4s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden;box-shadow:0 4px 20px #0000001a,0 1px 3px #0000001a}.project-card:before{content:"";opacity:0;pointer-events:none;z-index:1;background:linear-gradient(135deg,#3b82f60d 0%,#8b5cf60d 100%);transition:opacity .4s;position:absolute;inset:0}.project-card:hover{border-color:#3b82f666;transform:translateY(-12px)scale(1.02);box-shadow:0 25px 50px #3b82f626,0 10px 25px #0003}.project-card:hover:before{opacity:1}.project-image-container{background:linear-gradient(135deg,var(--color-background-secondary),var(--color-background-tertiary));width:100%;height:220px;position:relative;overflow:hidden}.project-image-container:after{content:"";pointer-events:none;z-index:2;background:linear-gradient(#0000 0% 60%,#1e293b4d 100%);position:absolute;inset:0}.project-image{filter:brightness(.9)contrast(1.1);transition:all .6s cubic-bezier(.4,0,.2,1)}.project-card:hover .project-image{filter:brightness()contrast(1.2);transform:scale(1.08)}.project-info{padding:var(--spacing-xl);z-index:2;flex-direction:column;flex-grow:1;display:flex;position:relative}.project-title{font-size:var(--font-size-lg);margin-bottom:var(--spacing-md);color:var(--color-text-primary);font-weight:var(--font-weight-bold);line-height:var(--line-height-tight);letter-spacing:-.01em;transition:color .3s}.project-card:hover .project-title{color:var(--color-accent-primary)}.project-description{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:var(--line-height-relaxed);margin-bottom:var(--spacing-lg);opacity:.9;flex-grow:1;transition:opacity .3s}.project-card:hover .project-description{opacity:1}.project-tech{gap:var(--spacing-sm);margin-bottom:var(--spacing-lg);flex-wrap:wrap;display:flex}.card-status{margin-top:var(--spacing-xl)}.project-links{gap:var(--spacing-sm);margin-top:var(--spacing-xl);display:flex}.project-link{padding:var(--spacing-xs)var(--spacing-sm);border:1px solid var(--color-accent-primary);color:var(--color-accent-primary);border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);align-items:center;gap:var(--spacing-xs);background-color:#0000;text-decoration:none;transition:all .2s;display:inline-flex}.project-link:hover{background-color:var(--color-accent-primary);color:var(--color-background-primary);transform:translateY(-2px)}.project-link.primary{background:linear-gradient(135deg,var(--color-accent-primary),var(--color-accent-tertiary));color:#fff;border:none}.project-link.primary:hover{background:linear-gradient(135deg,var(--color-accent-tertiary),var(--color-accent-primary));transform:translateY(-2px)}.project-status{padding:var(--spacing-xs)var(--spacing-sm);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);margin-bottom:var(--spacing-sm);display:inline-block}.project-status.live{color:#22c55e;background-color:#22c55e33;border:1px solid #22c55e4d}.project-status.development{color:#fbbf24;background-color:#fbbf2433;border:1px solid #fbbf244d}.project-status.archived{color:#9ca3af;background-color:#9ca3af33;border:1px solid #9ca3af4d}.project-modal-content{background-color:var(--color-background-secondary);border-radius:var(--radius-lg);border:1px solid #3b82f633;flex-direction:column;width:90%;max-width:1000px;max-height:90vh;display:flex;position:relative;overflow-y:auto;box-shadow:0 20px 40px #00000080}.project-modal-content::-webkit-scrollbar{width:8px}.project-modal-content::-webkit-scrollbar-track{background:var(--color-background-secondary);border-radius:var(--radius-md)}.project-modal-content::-webkit-scrollbar-thumb{background-color:var(--color-accent-primary);border-radius:var(--radius-md)}.project-modal-header{padding:var(--spacing-xl);border-bottom:1px solid #3b82f633}.project-modal-title{font-size:var(--font-size-2xl);color:var(--color-text-primary);margin-bottom:var(--spacing-sm)}.project-modal-body{padding:var(--spacing-xl);flex-grow:1}.project-modal-image{object-fit:cover;border-radius:var(--radius-md);width:100%;height:300px;margin-bottom:var(--spacing-lg)}.project-modal-description{font-size:var(--font-size-md);color:var(--color-text-secondary);line-height:var(--line-height-relaxed);margin-bottom:var(--spacing-lg)}.project-modal-tech{margin-bottom:var(--spacing-lg)}.project-modal-tech h4{color:var(--color-text-primary);margin-bottom:var(--spacing-sm)}.project-modal-links{gap:var(--spacing-md);flex-wrap:wrap;display:flex}@media (max-width:1200px){.projects-grid{gap:var(--spacing-lg);grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}}@media (max-width:768px){.projects-section{padding:var(--spacing-xl)0}.projects-grid{gap:var(--spacing-md);grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.project-card{border-radius:var(--radius-md)}.project-image-container{height:180px}.project-info{padding:var(--spacing-lg)}.project-links{gap:var(--spacing-xs);flex-direction:column}.project-modal-content{border-radius:var(--radius-md);width:95%;max-height:85vh}.project-modal-header,.project-modal-body{padding:var(--spacing-lg)}}@media (max-width:640px){.projects-grid{gap:var(--spacing-lg);grid-template-columns:1fr}.project-card:hover{transform:translateY(-6px)scale(1.01)}}@media (max-width:480px){.projects-section{padding:var(--spacing-lg)0}.category-title{font-size:var(--font-size-lg)}.project-image-container{height:160px}.project-info{padding:var(--spacing-md)}.project-modal-content{border-radius:var(--radius-sm);width:98%;max-height:80vh}.project-modal-header,.project-modal-body{padding:var(--spacing-md)}.project-modal-links{flex-direction:column}.project-card:hover{transform:translateY(-4px)}}
.skeleton-card{cursor:default;box-shadow:var(--shadow-regular)!important;transform:none!important}.skeleton-card:hover{box-shadow:var(--shadow-regular)!important;transform:none!important}.skeleton-card .photo-image,.skeleton-card .book-cover{transform:none!important}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.animate-pulse{animation:2s cubic-bezier(.4,0,.6,1) infinite pulse}.photo-image-container,.book-cover-container{background-color:var(--color-background-tertiary);position:relative}.skeleton-card .photo-image-container:before,.skeleton-card .book-cover-container:before{content:"";z-index:1;background:linear-gradient(90deg,#0000,#fff6,#0000);width:100%;height:100%;animation:1.5s infinite shimmer;display:block;position:absolute;top:0;left:-100%}@keyframes shimmer{0%{left:-100%}to{left:100%}}.loading-container{min-height:400px;color:var(--color-text-secondary);font-size:var(--font-size-lg);justify-content:center;align-items:center;display:flex}.error-container{text-align:center;padding:var(--spacing-2xl);color:var(--color-accent-primary);font-size:var(--font-size-lg)}.error-container h3{font-size:var(--font-size-xl);margin-bottom:var(--spacing-md)}.error-container p{margin-bottom:var(--spacing-lg);color:var(--color-text-secondary)}.retry-button{background-color:var(--color-accent-primary);color:#fff;padding:var(--spacing-sm)var(--spacing-lg);border-radius:var(--radius-md);cursor:pointer;font-size:var(--font-size-md);font-weight:var(--font-weight-medium);border:none;transition:background-color .2s}.retry-button:hover{background-color:var(--color-accent-tertiary)}
