.project-gallery__grid{grid-template-columns:repeat(2,1fr);gap:.75rem;display:grid}@media (min-width:768px){.project-gallery__grid[data-columns="3"]{grid-template-columns:repeat(3,1fr)}.project-gallery__grid[data-columns="2"]{grid-template-columns:repeat(2,1fr)}.project-gallery__grid{gap:1rem}}.project-gallery__card{aspect-ratio:4/3;cursor:pointer;background:#2b2b2b0f;border:none;border-radius:8px;padding:0;transition:transform .3s;position:relative;overflow:hidden}.project-gallery__card:hover,.project-gallery__card:focus-visible{transform:scale(1.02)}.project-gallery__card:hover .project-gallery__card-overlay,.project-gallery__card:focus-visible .project-gallery__card-overlay{opacity:1}.project-gallery__card:hover .project-gallery__cover,.project-gallery__card:focus-visible .project-gallery__cover{transform:scale(1.05)}.project-gallery__cover{object-fit:cover;width:100%;height:100%;transition:transform .4s}.project-gallery__cover-wrapper{width:100%;height:100%}.project-gallery__cover-wrapper img{transition:opacity .3s}.project-gallery__spinner{border:2px solid #2b2b2b1a;border-top-color:#2b2b2b66;border-radius:50%;width:24px;height:24px;animation:.7s linear infinite gallerySpin;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.project-gallery__lightbox-img-wrapper{justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:relative}.project-gallery__lightbox-img-wrapper img{transition:opacity .3s}.project-gallery__card-overlay{opacity:0;background:linear-gradient(#0000 0%,#2b2b2b1a 50%,#2b2b2bbf 100%);flex-direction:column;justify-content:flex-end;padding:1rem;transition:opacity .3s;display:flex;position:absolute;inset:0}.project-gallery__card-title{color:#f2e8dc;font-family:Cormorant Garamond,Georgia,serif;font-size:1rem;font-weight:600;line-height:1.3}.project-gallery__card-count{color:#f2e8dcb3;letter-spacing:.04em;margin-top:.2rem;font-family:Lato,Helvetica Neue,Arial,sans-serif;font-size:.7rem;font-weight:300}.project-gallery__lightbox{z-index:1000;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#2b2b2beb;justify-content:center;align-items:center;animation:.25s galleryFadeIn;display:flex;position:fixed;inset:0}.project-gallery__lightbox-content{flex-direction:column;width:100%;max-width:900px;max-height:95vh;padding:1rem;display:flex;position:relative}@media (min-width:768px){.project-gallery__lightbox-content{padding:1.5rem}}.project-gallery__lightbox-header{align-items:center;gap:.75rem;margin-bottom:1rem;display:flex}.project-gallery__lightbox-title{color:#f2e8dc;flex:1;font-family:Cormorant Garamond,Georgia,serif;font-size:1.1rem;font-weight:600}.project-gallery__lightbox-counter{color:#f2e8dc80;letter-spacing:.05em;font-family:Lato,Helvetica Neue,Arial,sans-serif;font-size:.75rem;font-weight:300}.project-gallery__lightbox-close{cursor:pointer;color:#f2e8dc99;background:0 0;border:none;padding:.25rem;transition:color .2s}.project-gallery__lightbox-close:hover{color:#f2e8dc}.project-gallery__lightbox-close svg{width:24px;height:24px}.project-gallery__lightbox-media{background:#2b2b2b66;border-radius:6px;flex:1;justify-content:center;align-items:center;min-height:0;display:flex;overflow:hidden}.project-gallery__lightbox-img{object-fit:contain;-webkit-user-select:none;user-select:none;border-radius:6px;max-width:100%;max-height:65vh}.project-gallery__lightbox-video{border-radius:6px;outline:none;max-width:100%;max-height:65vh}.project-gallery__lightbox-arrow{cursor:pointer;color:#f2e8dcb3;background:#f2e8dc14;border:1px solid #f2e8dc1f;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;transition:background-color .2s,color .2s;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.project-gallery__lightbox-arrow:hover{color:#f2e8dc;background:#f2e8dc26}.project-gallery__lightbox-arrow svg{width:20px;height:20px}.project-gallery__lightbox-arrow--prev{left:.5rem}@media (min-width:768px){.project-gallery__lightbox-arrow--prev{left:-.5rem}}.project-gallery__lightbox-arrow--next{right:.5rem}@media (min-width:768px){.project-gallery__lightbox-arrow--next{right:-.5rem}}.project-gallery__lightbox-thumbs{justify-content:center;gap:.5rem;margin-top:1rem;padding-bottom:.25rem;display:flex;overflow-x:auto}.project-gallery__lightbox-thumbs::-webkit-scrollbar{height:3px}.project-gallery__lightbox-thumbs::-webkit-scrollbar-thumb{background:#f2e8dc26;border-radius:2px}.project-gallery__lightbox-thumb{cursor:pointer;opacity:.5;background:#f2e8dc0d;border:2px solid #0000;border-radius:4px;flex-shrink:0;width:56px;height:42px;padding:0;transition:opacity .2s,border-color .2s;overflow:hidden}.project-gallery__lightbox-thumb:hover{opacity:.8}.project-gallery__lightbox-thumb--active{opacity:1;border-color:#f2e8dc}.project-gallery__lightbox-thumb img{object-fit:cover;width:100%;height:100%}.project-gallery__lightbox-thumb-video{color:#f2e8dc99;background:#2b2b2b66;justify-content:center;align-items:center;width:100%;height:100%;display:flex}.project-gallery__lightbox-thumb-video svg{width:16px;height:16px}@keyframes galleryFadeIn{0%{opacity:0}to{opacity:1}}@keyframes gallerySpin{to{transform:translate(-50%,-50%)rotate(360deg)}}
