/* RUNHAMS LP COMMERCIAL - GALLERY + MODAL */
.runhams-lp-offices-gallery { background-color: #f3f3f3; padding: 0; line-height: 0; }
.runhams-lp-offices-gallery-inner { display: grid; grid-template-columns: repeat(4, 1fr); }
.runhams-lp-offices-gallery-item { display: block; height: 200px; background-size: cover; background-position: center; cursor: pointer; text-decoration: none; position: relative; transition: transform 0.3s ease; overflow: hidden; }
.runhams-lp-offices-gallery-item::after { content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 40%; background: linear-gradient(transparent, rgba(0,0,0,0.25)); pointer-events: none; transition: opacity 0.3s ease; }
.runhams-lp-offices-gallery-item:hover { transform: scale(1.03); z-index: 1; }
.runhams-lp-offices-gallery-item:hover::after { opacity: 0; }
.runhams-lp-offices-modal { display: none; position: fixed; z-index: 1000; top: 0; left: 0; width: 100%; height: 100%; background-color: rgba(0,0,0,0.92); justify-content: center; align-items: center; padding: 2rem; }
.runhams-lp-offices-modal[style*="display: flex"] { display: flex !important; }
.runhams-lp-offices-modal-img { max-width: 90%; max-height: 90vh; object-fit: contain; border-radius: 4px; box-shadow: 0 8px 32px rgba(0,0,0,0.5); }
.runhams-lp-offices-modal-close { position: absolute; top: 1.25rem; right: 1.5rem; color: #fff; font-size: 2rem; font-weight: 300; cursor: pointer; background: none; border: none; padding: 0.5rem; line-height: 1; z-index: 1001; transition: opacity 0.3s ease; }
.runhams-lp-offices-modal-close:hover { opacity: 0.7; }

@media (max-width: 1024px) { .runhams-lp-offices-gallery-inner { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 768px) { .runhams-lp-offices-gallery-item { height: 170px; } }
@media (max-width: 480px) { .runhams-lp-offices-gallery-item { height: 140px; } .runhams-lp-offices-modal-img { max-width: 95%; } .runhams-lp-offices-modal-close { top: 0.75rem; right: 1rem; font-size: 1.75rem; } }
