.gallery-page-container{background-color:var(--primary-color);min-height:100vh;padding:100px 0 0;position:relative}.gallery-page-header{text-align:center;margin-bottom:3rem;padding:0 2rem}.gallery-page-title{margin-bottom:1rem;font-family:Playfair Display,serif;font-size:2.5rem;font-weight:700}.gallery-page-subtitle{color:#666;max-width:700px;margin:0 auto;font-family:Raleway,sans-serif;font-size:1.2rem}.gallery-page-grid{grid-template-columns:repeat(1,1fr);gap:2rem;max-width:1400px;margin:0 auto;padding:0 2rem;display:grid}@media (min-width:640px){.gallery-page-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width:1024px){.gallery-page-grid{grid-template-columns:repeat(3,1fr)}}.gallery-page-item{height:350px;color:inherit;border-radius:8px;text-decoration:none;display:block;position:relative;overflow:hidden;box-shadow:0 4px 20px #0000001a}.gallery-page-image-container{width:100%;height:100%;overflow:hidden}.gallery-page-image{object-fit:cover;width:100%;height:100%;transition:transform .7s}.gallery-page-item:hover .gallery-page-image{transform:scale(1.05)}.gallery-page-overlay{color:#fff;background:linear-gradient(#0000,#000c);padding:2rem 1.5rem;transition:all .3s;position:absolute;bottom:0;left:0;right:0}.gallery-page-item:hover .gallery-page-overlay{background:linear-gradient(#00000080,#000000e6)}.gallery-page-project-title{margin-bottom:.5rem;font-family:Playfair Display,serif;font-size:1.5rem;font-weight:600}.gallery-page-description{opacity:.9;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:1rem;font-family:Raleway,sans-serif;font-size:.9rem;display:-webkit-box;overflow:hidden}.gallery-page-view-project{opacity:0;border-bottom:2px solid #fff;padding-bottom:2px;font-family:Raleway,sans-serif;font-size:.9rem;font-weight:500;transition:all .3s;display:inline-block;transform:translateY(10px)}.gallery-page-item:hover .gallery-page-view-project{opacity:1;transform:translateY(0)}.gallery-page-loading{flex-direction:column;justify-content:center;align-items:center;min-height:400px;display:flex}.gallery-page-spinner{border:3px solid #0000001a;border-top-color:#222;border-radius:50%;width:50px;height:50px;margin-bottom:1rem;animation:1s ease-in-out infinite gallery-page-spin}@keyframes gallery-page-spin{to{transform:rotate(360deg)}}.gallery-page-error{text-align:center;max-width:600px;margin:0 auto;padding:3rem 1rem}.gallery-page-error h2{color:#d32f2f;margin-bottom:1rem;font-size:1.8rem}.gallery-page-error p{color:#666;margin-bottom:2rem}.gallery-page-error-actions{justify-content:center;gap:1rem;display:flex}.gallery-page-button{color:#fff;cursor:pointer;background-color:#222;border:none;border-radius:4px;padding:.75rem 1.5rem;font-size:1rem;text-decoration:none;transition:background-color .3s;display:inline-block}.gallery-page-button:hover{background-color:#444}.gallery-page-empty{text-align:center;color:#666;padding:3rem 1rem}
