.projects-section{padding:var(--spacing-2xl)0;position:relative}.projects-grid .project-card{opacity:0;animation:.6s ease-out forwards fadeInUp;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:.6s ease-out forwards slideIn;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;text-decoration:none;transition:all .4s cubic-bezier(.4,0,.2,1);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,rgba(30,41,59,.95) 0%,rgba(30,41,59,.85) 100%);border:1px solid rgba(59,130,246,.15);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 rgba(0,0,0,.1),0 1px 3px rgba(0,0,0,.1)}.project-card:before{content:"";opacity:0;pointer-events:none;z-index:1;background:linear-gradient(135deg,rgba(59,130,246,.05) 0%,rgba(139,92,246,.05) 100%);transition:opacity .4s;position:absolute;top:0;bottom:0;left:0;right:0}.project-card:hover{border-color:rgba(59,130,246,.4);transform:translateY(-12px)scale(1.02);box-shadow:0 25px 50px rgba(59,130,246,.15),0 10px 25px rgba(0,0,0,.2)}.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(transparent 0%,transparent 60%,rgba(30,41,59,.3) 100%);position:absolute;top:0;bottom:0;left:0;right: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:transparent;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:rgba(34,197,94,.2);border:1px solid rgba(34,197,94,.3)}.project-status.development{color:#fbbf24;background-color:rgba(251,191,36,.2);border:1px solid rgba(251,191,36,.3)}.project-status.archived{color:#9ca3af;background-color:rgba(156,163,175,.2);border:1px solid rgba(156,163,175,.3)}.project-modal-content{background-color:var(--color-background-secondary);border-radius:var(--radius-lg);border:1px solid rgba(59,130,246,.2);flex-direction:column;width:90%;max-width:1000px;max-height:90vh;display:flex;position:relative;overflow-y:auto;box-shadow:0 20px 40px rgba(0,0,0,.5)}.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 rgba(59,130,246,.2)}.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,transparent,rgba(255,255,255,.4),transparent);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)}
.video-player-container{background:#000;border-radius:8px;width:100%;position:relative;overflow:hidden}.video-player{border-radius:8px;width:100%;height:auto}.video-loading{color:#fff;z-index:10;flex-direction:column;align-items:center;gap:1rem;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.video-loading .spinner{border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;width:40px;height:40px;animation:1s linear infinite spin}.video-title{color:#fff;background:rgba(0,0,0,.8);padding:1rem}.video-title h3{margin:0;font-size:1.2rem;font-weight:600}.video-player-error{color:#fff;background:#1a1a1a;border-radius:8px;justify-content:center;align-items:center;min-height:300px;display:flex}.error-content{text-align:center;padding:2rem}.error-content h3{color:#ff6b6b;margin-bottom:1rem}.error-content p{opacity:.8;margin-bottom:1.5rem}.video-modal-overlay{z-index:1002!important;-webkit-backdrop-filter:blur(5px)!important;backdrop-filter:blur(5px)!important;background-color:rgba(0,0,0,.8)!important;justify-content:center!important;align-items:center!important;padding:1rem!important;display:flex!important;position:fixed!important;top:0!important;bottom:0!important;left:0!important;right:0!important;overflow:hidden!important}.modal-close{color:#fff;cursor:pointer;z-index:10;background:rgba(0,0,0,.7);border:none;border-radius:50%;justify-content:center;align-items:center;width:30px;height:30px;font-size:20px;transition:background-color .2s;display:flex;position:absolute;top:10px;right:10px}.modal-close:hover{background-color:rgba(0,0,0,.9)}.video-modal-content{background:var(--background-secondary);border:1px solid rgba(203,213,225,.1);border-radius:16px;flex-direction:column;width:1000px;max-width:90vw;max-height:95vh;padding:0;display:flex;position:relative;overflow:hidden;box-shadow:0 25px 50px -12px rgba(0,0,0,.25)}.video-modal-header{border-bottom:1px solid rgba(203,213,225,.1);padding:2rem 2rem 1rem}.video-modal-title{color:var(--text-primary);margin:0 0 .5rem;font-size:2rem;font-weight:700}.video-modal-date{color:var(--text-secondary);margin:0;font-size:.9rem}.video-modal-body{flex:1;min-height:0;padding:0;overflow-y:auto}.video-modal-player{background:#000;width:100%;position:relative}.modal-video-player{width:100%;height:auto;max-height:-moz-fit-content;max-height:fit-content}.video-modal-description{padding:2rem}.video-modal-description h3{color:var(--text-primary);margin:0 0 1rem;font-weight:600}.video-modal-description p{color:var(--text-secondary);margin:0;line-height:1.6}.video-card{background:var(--background-secondary);cursor:pointer;border:1px solid rgba(203,213,225,.1);border-radius:12px;transition:all .3s;position:relative;overflow:hidden}.video-card:hover{border-color:var(--accent-primary);transform:translateY(-5px);box-shadow:0 20px 40px rgba(0,0,0,.1)}.video-card-thumbnail{background:#000;width:100%;height:200px;position:relative;overflow:hidden}.video-card-thumbnail img{object-fit:cover;width:100%;height:100%;transition:transform .3s}.video-card:hover .video-card-thumbnail img{transform:scale(1.05)}.video-card-play-button{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:rgba(255,255,255,.9);border-radius:50%;justify-content:center;align-items:center;width:60px;height:60px;transition:all .3s;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.video-card-play-button:after{content:"";border-top:12px solid transparent;border-bottom:12px solid transparent;border-left:20px solid #333;width:0;height:0;margin-left:4px}.video-card:hover .video-card-play-button{background:var(--accent-primary);transform:translate(-50%,-50%)scale(1.1)}.video-card:hover .video-card-play-button:after{border-left-color:#fff}.video-card-content{padding:1.5rem}.video-card-title{color:var(--text-primary);margin:0 0 .5rem;font-size:1.1rem;font-weight:600;line-height:1.3}.video-card-description{color:var(--text-secondary);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:.9rem;line-height:1.4;display:-webkit-box;overflow:hidden}.video-card-meta{color:var(--text-secondary);border-top:1px solid rgba(203,213,225,.1);margin-top:1rem;padding-top:1rem;font-size:.8rem}.video-thumbnail-placeholder{background:var(--background-secondary);width:100%;height:100%;color:var(--text-secondary);justify-content:center;align-items:center;display:flex}@media (max-width:768px){.video-modal-content{flex-direction:column;width:95vw;max-height:95vh;display:flex}.video-modal-header{padding:1.5rem 1.5rem 1rem}.video-modal-title{font-size:1.5rem}.video-modal-description{padding:1.5rem}.modal-video-player{max-height:50vh}.video-card-thumbnail{height:160px}.video-card-play-button{width:50px;height:50px}.video-card-play-button:after{border-top:10px solid transparent;border-bottom:10px solid transparent;border-left:16px solid #333}}@media (max-width:480px){.video-modal-content{border-radius:8px;flex-direction:column;width:98vw;max-height:98vh;display:flex}.video-modal-header{padding:1rem}.video-modal-title{font-size:1.3rem}.video-modal-description{padding:1rem}.modal-video-player{max-height:40vh}}
