.loading-container{display:flex;align-items:center;justify-content:center;min-height:50vh;width:100%}.spinner-circle{width:40px;height:40px;position:relative}.spinner-inner{width:100%;height:100%;border:3px solid var(--bg-secondary);border-top:3px solid var(--text-accent);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 768px){.spinner-circle{width:35px;height:35px}}.project-modal-backdrop-container{position:fixed;top:0;left:0;width:100%;height:100%;z-index:9999;pointer-events:none;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:backdrop-filter .2s ease-out,-webkit-backdrop-filter .2s ease-out,opacity .2s ease-out;opacity:1}.project-modal-backdrop-container.closing{backdrop-filter:blur(0px);-webkit-backdrop-filter:blur(0px);opacity:0}.project-modal-backdrop{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;padding:20px;box-sizing:border-box;pointer-events:all}[data-theme=dark] .project-modal-backdrop{background-color:#0000004d}.project-modal{width:90%;max-width:900px;max-height:90vh;border-radius:16px;overflow:hidden;display:flex;flex-direction:column;position:relative;z-index:10000}.modal-close-btn{position:absolute;top:15px;right:15px;background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border);border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;z-index:10001;transition:all .2s ease;font-size:1.2rem}.modal-close-btn:hover{background:var(--bg-card);transform:scale(1.1)}.modal-header{padding:20px 60px 15px 20px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border)}.modal-header h3{margin:0;font-size:1.3rem;color:var(--text-primary);max-width:80%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.modal-pagination{font-size:.9rem;color:var(--text-secondary);background:var(--bg-secondary);padding:5px 12px;border-radius:20px;border:1px solid var(--border);flex-shrink:0}.modal-body{flex:1;overflow:hidden;position:relative;display:flex;flex-direction:column}.modal-swiper{width:100%;height:100%;flex:1}.modal-slide{display:flex!important;align-items:center;justify-content:center;height:100%}.modal-image-container{width:100%;height:100%;display:flex;align-items:center;justify-content:center;position:relative;max-height:60vh;object-fit:contain;flex-shrink:0;padding:20px}.modal-image{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;border-radius:8px;opacity:0;transition:opacity .3s ease;box-shadow:0 4px 20px #0003}.modal-image.image-loaded{opacity:1}.modal-swiper-navigation{padding:15px 20px;display:flex;align-items:center;justify-content:space-between;gap:20px;border-top:1px solid var(--border);min-height:70px}.modal-swiper-pagination{display:flex;gap:8px;align-items:center;justify-content:center;flex-wrap:wrap;flex:1}.modal-bullet{cursor:var(--cursor-pointer);width:10px;height:10px;border-radius:50%;background:var(--bg-secondary);display:inline-block;transition:all .3s ease;border:1px solid var(--border)}.modal-bullet-active{cursor:var(--cursor-pointer);background:var(--text-accent);transform:scale(1.2);border-color:var(--text-accent)}.custom-nav-button{width:40px;height:40px;border-radius:50%;background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-primary);display:flex;align-items:center;justify-content:center;transition:all .2s ease;font-size:1.3rem;flex-shrink:0}.custom-nav-button:hover:not(:disabled){background:var(--bg-card);transform:scale(1.1);box-shadow:0 4px 12px var(--shadow)}.custom-nav-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.custom-nav-button:disabled:hover{background:var(--bg-secondary);box-shadow:none}.modal-image-loading-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);border-radius:8px;z-index:1}.image-placeholder-loader{display:none}.modal-image-description-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(0,0,0,.5) 0%,transparent 100%);padding:20px 16px 16px;border-radius:0 0 8px 8px;z-index:2}.modal-image-description-overlay p{margin:0;color:#fff;font-size:.9rem;line-height:1.4;text-align:center;text-shadow:0 1px 2px rgba(0,0,0,.5)}.modal-image-description{display:none}@media (max-width: 768px){.project-modal{width:95%;max-height:85vh}.modal-header{padding:15px 50px 15px 15px}.modal-header h3{font-size:1.1rem;max-width:50%}.modal-close-btn{width:35px;height:35px;top:10px;right:10px;font-size:1rem}.modal-slide{padding:20px 15px}.modal-image-container{max-height:50vh}.modal-image-description-overlay{padding:16px 12px 12px}.modal-image-description-overlay p{font-size:.85rem}.custom-nav-button{width:35px;height:35px;font-size:1.1rem}.modal-bullet{width:8px;height:8px}.modal-swiper-navigation{padding:12px 15px;min-height:60px}}@media (max-width: 480px){.project-modal-backdrop{padding:10px}.project-modal{width:100%;max-height:90vh}.modal-header{padding:12px 45px 12px 12px}.modal-header h3{font-size:1rem;max-width:45%}.modal-pagination{font-size:.8rem;padding:3px 8px}.modal-slide{padding:15px 10px}.modal-image-container{max-height:45vh}.modal-image-description-overlay{padding:12px 10px 10px}.modal-image-description-overlay p{font-size:.8rem;line-height:1.3}.modal-swiper-navigation{padding:10px;gap:15px;min-height:55px}.custom-nav-button{width:32px;height:32px;font-size:1rem}.modal-bullet{width:6px;height:6px}.modal-swiper-pagination{gap:6px}}.modal-swiper .swiper-button-next,.modal-swiper .swiper-button-prev{display:none!important}.modal-swiper .swiper-slide{width:100%!important;flex-shrink:0}.modal-swiper .swiper-wrapper{align-items:center}.projects-page{padding:40px 20px;min-height:calc(100vh - 200px);width:100%;position:relative;display:flex;align-items:center;justify-content:center;box-sizing:border-box;overflow-x:hidden}.projects-content{padding:40px;max-width:1200px;width:100%;text-align:center;margin:0 auto;box-sizing:border-box;overflow:hidden}.projects-filters{display:flex;justify-content:center;gap:12px;flex-wrap:wrap}.filter-button{background:var(--bg-secondary);color:var(--text-secondary);border:1px solid var(--border);border-radius:30px;padding:8px 20px;font-size:.9rem;transition:all .3s ease}.filter-button:hover{background:var(--bg-card);color:var(--text-primary);transform:translateY(-2px)}.filter-button.active{background:var(--bg-card);color:var(--text-primary);border-color:var(--text-accent);box-shadow:0 4px 12px var(--shadow)}.projects-container{margin-top:20px;width:100%;position:relative;flex:1}.project-card{margin-bottom:0;overflow:hidden;display:flex;flex-direction:column;border-radius:16px;height:100%;transition:transform .3s ease,box-shadow .3s ease}.project-card:hover{transform:translateY(-5px);box-shadow:0 10px 30px var(--shadow)}.project-image-container{width:100%;height:220px;overflow:hidden;position:relative;background:var(--bg-secondary)}.image-loading{position:relative}.image-placeholder-loader{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,var(--bg-secondary) 25%,var(--bg-card) 50%,var(--bg-secondary) 75%);background-size:200% 100%;animation:loadingAnimation 1.5s infinite;z-index:1}@keyframes loadingAnimation{0%{background-position:200% 0}to{background-position:-200% 0}}.project-image{width:100%;height:100%;object-fit:cover;transition:transform .3s ease;opacity:1}.project-card:hover .project-image.image-loaded{transform:scale(1.05)}.project-content{padding:20px;display:flex;flex-direction:column;flex-grow:1}.project-title{margin:0 0 10px;color:var(--text-primary);font-size:1.3rem}.project-description{color:var(--text-secondary);font-size:.95rem;margin-bottom:15px;line-height:1.5;flex-grow:1}.project-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}.project-tag{background:var(--bg-secondary);color:var(--text-secondary);font-size:.8rem;padding:3px 10px;border-radius:20px;border:1px solid var(--border)}.project-links{display:flex;gap:10px;justify-content:center;margin-top:auto}.project-link{font-size:.9rem!important;padding:8px 16px!important}.projects-swiper{padding:10px 0 50px;touch-action:pan-y;height:100%;width:100%;overflow:hidden}.swiper-slide{height:auto!important;display:flex;justify-content:center;touch-action:pan-y;pointer-events:auto!important}@media (min-width: 641px){.swiper-slide{width:330px!important}}.story-swiper{width:100%;padding:0 0 50px!important}.story-card{box-shadow:0 8px 30px var(--shadow);border-radius:16px}.story-progress-container.fixed{position:relative;width:100%;padding:0 15px 15px;z-index:2;margin-top:5px;display:flex;flex-direction:row;align-items:center;justify-content:center;gap:8px}.story-progress-dot{height:8px;width:8px;background-color:#fff3;border-radius:50%;transition:all .3s ease}.story-progress-dot.active{background-color:var(--text-accent);transform:scale(1.2)}.story-progress-dot.completed{background-color:var(--text-accent)}.swipe-indicator{display:flex;align-items:center;justify-content:center;margin:0 0 10px;color:var(--text-secondary);font-size:.9rem;animation:pulse 2s infinite;gap:10px;-webkit-user-select:none;user-select:none}@keyframes pulse{0%{opacity:.6}50%{opacity:1}to{opacity:.6}}.mobile-view .projects-container{height:calc(100% - 100px);overflow:hidden}.mobile-view .story-swiper{height:100%}.projects-grid-container{margin-top:20px;width:100%}.projects-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;width:100%;box-sizing:border-box}.pagination-controls{display:flex;align-items:center;justify-content:center;margin-top:25px;gap:15px;-webkit-user-select:none;user-select:none}.pagination-button{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border);border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;transition:all .3s ease;font-size:1.2rem}.pagination-button:hover:not(.disabled){background:var(--bg-card);transform:translateY(-2px);box-shadow:0 4px 12px var(--shadow)}.pagination-button.disabled{opacity:.5;cursor:not-allowed}.pagination-numbers{display:flex;gap:8px;align-items:center}.pagination-number{background:var(--bg-secondary);color:var(--text-secondary);border:1px solid var(--border);border-radius:50%;width:35px;height:35px;display:flex;align-items:center;justify-content:center;transition:all .3s ease;font-size:.9rem}.pagination-number.active{background:var(--bg-card);color:var(--text-primary);border-color:var(--text-accent);box-shadow:0 4px 12px var(--shadow);transform:scale(1.1)}.pagination-number:hover:not(.active){background:var(--bg-card);transform:translateY(-2px)}.multiple-images-indicator{position:absolute;top:10px;right:10px;background:#0009;color:#fff;border-radius:20px;padding:3px 10px;font-size:.8rem;font-weight:700;z-index:2;pointer-events:none}@media (max-width: 1240px){.projects-content{padding:30px}.projects-grid{gap:15px}}@media (max-width: 992px){.projects-grid{grid-template-columns:repeat(2,1fr)}.pagination-button{width:36px;height:36px}.pagination-number{width:32px;height:32px;font-size:.85rem}}@media (max-width: 768px){.projects-page{padding:0;min-height:90vh;display:flex;align-items:center;justify-content:center}.projects-content{padding:25px 20px}.projects-grid{grid-template-columns:1fr}.pagination-controls{margin-top:20px;gap:10px}.pagination-numbers{gap:5px}.mobile-view{touch-action:none;overflow:hidden;height:80vh;max-height:90vh;position:relative;border-radius:16px;padding:20px 15px!important;display:flex;flex-direction:column;width:90%;margin:0 auto;top:auto;left:auto;transform:none}.story-progress-container.fixed{padding:0 10px 10px}.story-progress-dot{height:6px;width:6px}}@media (max-width: 480px){.projects-page{padding:0}.projects-content{padding:20px 15px;width:95%}.projects-content h1{font-size:1.8rem}.project-image-container{height:180px}.project-title{font-size:1.2rem}.project-description{font-size:.9rem}.story-progress-dot{height:5px;width:5px}}.projects-grid-swiper,.projects-grid-swiper .swiper-slide{display:none}
