.gallery{background:var(--color-shade-01);padding:100px 0}.gallery__headline{font-family:var(--font-heading);font-weight:400;font-size:44px;line-height:1.15;color:var(--color-harbor-sage);text-align:center;margin:0 0 48px}.gallery__grid{display:flex;gap:24px;align-items:stretch}.gallery__item{margin:0;position:relative;overflow:hidden}.gallery__item--main{flex:0 0 calc(36% - 12px)}.gallery__link{display:block;width:100%;height:100%;position:relative;overflow:hidden;cursor:zoom-in;text-decoration:none;background:var(--color-harbor-sage)}.gallery__link img{width:100%;height:100%;display:block;object-fit:cover;transition:transform .3s ease,opacity .2s ease}.gallery__link::after{content:"";position:absolute;inset:0;background:var(--color-harbor-sage);opacity:0;transition:opacity .2s ease;pointer-events:none}.gallery__link:hover img,.gallery__link:focus-visible img{transform:scale(1.03)}.gallery__link:hover::after,.gallery__link:focus-visible::after{opacity:.55}.gallery__link:focus-visible{outline:3px solid var(--color-harbor-sage);outline-offset:3px}.gallery__link:active img{transform:scale(0.99)}.gallery__sub-grid{flex:1 1 auto;aspect-ratio:800/657;display:grid;grid-template-columns:repeat(24, 1fr);grid-template-rows:1fr 1.22fr;gap:24px}.gallery__sub-grid .gallery__item:nth-child(1){grid-column:span 8;grid-row:1}.gallery__sub-grid .gallery__item:nth-child(2){grid-column:span 16;grid-row:1}.gallery__sub-grid .gallery__item:nth-child(3){grid-column:span 13;grid-row:2}.gallery__sub-grid .gallery__item:nth-child(4){grid-column:span 11;grid-row:2}.gallery__ctas{display:flex;flex-wrap:wrap;justify-content:center;gap:16px;margin-top:48px}.gallery__cta{position:relative;display:inline-flex;align-items:center;justify-content:center;padding:16px 32px;min-height:44px;min-width:44px;background:var(--color-weathered-taupe-700);border:0;border-radius:0;font-family:var(--font-primary);font-weight:500;font-size:20px;letter-spacing:.12em;text-transform:uppercase;color:var(--color-shade-01);text-decoration:none;cursor:pointer;transition:background .2s ease,color .2s ease,box-shadow .2s ease}.gallery__cta::before{content:"";position:absolute;inset:5px;border:2px solid var(--color-shade-01);pointer-events:none;transition:border-color .2s ease}.gallery__cta:hover{background:var(--color-eucalyptus-mist);color:var(--color-riverstone-900);box-shadow:0 6px 16px rgba(0,0,0,.18)}.gallery__cta:hover::before{border-color:var(--color-riverstone-900)}.gallery__cta:focus{outline:2px solid var(--color-weathered-taupe-700);outline-offset:3px}.gallery__cta:active{transform:scale(0.98)}@media(max-width: 1024px){.gallery{padding:80px 0}.gallery__headline{font-size:36px;margin-bottom:36px}.gallery__grid{gap:16px}.gallery__sub-grid{gap:16px}}@media(max-width: 768px){.gallery{padding:60px 0}.gallery__headline{font-size:30px;margin-bottom:28px}.gallery__grid{margin-inline:-30px;padding:0 40px;display:flex;flex-wrap:nowrap;overflow-x:scroll;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:10px}.gallery__grid::-webkit-scrollbar{display:none}.gallery__item--main{flex:unset}.gallery__sub-grid{display:contents}.gallery__item{flex:0 0 calc(100vw - 80px);scroll-snap-align:center;aspect-ratio:4/3;overflow:hidden;grid-column:unset !important;grid-row:unset !important}.gallery__link{height:100%;aspect-ratio:unset}}@media(max-width: 768px){.gallery__ctas{margin-top:32px}.gallery__cta{font-size:18px;flex:1 1 100%;text-align:center}}@media(prefers-reduced-motion: reduce){.gallery__link img,.gallery__link::after{transition:none}.gallery__cta{transition:none}.gallery__cta:active{transform:none}}.mfp-gallery.mfp-bg{background:var(--color-harbor-sage);opacity:0;transition:opacity .3s ease}.mfp-gallery.mfp-bg.mfp-ready{opacity:1}.mfp-gallery.mfp-bg.mfp-removing{opacity:0}.mfp-gallery .mfp-content{opacity:0;transition:opacity .3s ease}.mfp-gallery.mfp-ready .mfp-content{opacity:1}.mfp-gallery .mfp-img{padding:60px 0;max-height:calc(100vh - 120px)}.mfp-gallery .mfp-figure::after{display:none}.mfp-gallery .mfp-bottom-bar{position:absolute;width:1px;height:1px;margin:-1px;padding:0;border:0;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap}.mfp-gallery .mfp-arrow,.mfp-gallery button.mfp-close{width:64px;height:64px;border-radius:50%;background:var(--color-shade-01);box-shadow:0 12px 32px rgba(78,90,85,.28),0 4px 10px rgba(78,90,85,.18);opacity:1;padding:0;cursor:pointer;transition:background .2s ease,transform .15s ease,box-shadow .2s ease}.mfp-gallery .mfp-arrow:hover,.mfp-gallery button.mfp-close:hover{background:var(--color-harbor-sage);box-shadow:0 14px 38px rgba(78,90,85,.34),0 6px 14px rgba(78,90,85,.22)}.mfp-gallery .mfp-arrow:active,.mfp-gallery button.mfp-close:active{transform:scale(0.96)}.mfp-gallery .mfp-arrow:focus-visible,.mfp-gallery button.mfp-close:focus-visible{outline:3px solid var(--color-shade-01);outline-offset:3px}.mfp-gallery .mfp-figure>.mfp-close{display:none}.mfp-gallery button.mfp-close{position:absolute;right:32px;top:32px;font-size:0;color:rgba(0,0,0,0);line-height:64px}.mfp-gallery button.mfp-close::before,.mfp-gallery button.mfp-close::after{content:"";position:absolute;top:50%;left:50%;width:24px;height:2.5px;background:var(--color-harbor-sage);border-radius:2px;transition:background .2s ease}.mfp-gallery button.mfp-close::before{transform:translate(-50%, -50%) rotate(45deg)}.mfp-gallery button.mfp-close::after{transform:translate(-50%, -50%) rotate(-45deg)}.mfp-gallery button.mfp-close:hover::before,.mfp-gallery button.mfp-close:hover::after{background:var(--color-shade-01)}.mfp-gallery .mfp-arrow{margin-top:-32px}.mfp-gallery .mfp-arrow::before,.mfp-gallery .mfp-arrow::after{margin:0;border:0;background:none}.mfp-gallery .mfp-arrow::after{content:"";position:absolute;top:50%;left:50%;width:16px;height:16px;border-top:3px solid var(--color-harbor-sage);border-left:3px solid var(--color-harbor-sage);border-right:0;border-bottom:0;border-radius:2px;transition:border-color .2s ease;opacity:1}.mfp-gallery .mfp-arrow:hover::after{border-color:var(--color-shade-01)}.mfp-gallery .mfp-arrow-left{left:32px}.mfp-gallery .mfp-arrow-left::after{transform:translate(-30%, -50%) rotate(-45deg)}.mfp-gallery .mfp-arrow-right{right:32px}.mfp-gallery .mfp-arrow-right::after{transform:translate(-70%, -50%) rotate(135deg)}@media(max-width: 768px){.mfp-gallery .mfp-img{padding:80px 0;max-height:calc(100vh - 160px)}.mfp-gallery button.mfp-close{width:38px;height:38px;line-height:38px;right:16px;top:16px}.mfp-gallery button.mfp-close::before,.mfp-gallery button.mfp-close::after{width:18px;height:2px}.mfp-gallery .mfp-arrow{width:48px;height:48px;margin-top:-24px}.mfp-gallery .mfp-arrow::after{width:12px;height:12px;border-width:2.5px}.mfp-gallery .mfp-arrow-left{left:12px}.mfp-gallery .mfp-arrow-right{right:12px}}@media(prefers-reduced-motion: reduce){.mfp-gallery.mfp-bg,.mfp-gallery .mfp-content,.mfp-gallery .mfp-close,.mfp-gallery .mfp-arrow,.mfp-gallery .mfp-close::before,.mfp-gallery .mfp-close::after,.mfp-gallery .mfp-arrow::after{transition:none}}
