/* Gallery Styles by Tessa */
.tessa-gallery-wrapper .m-b-40 { margin-bottom: 40px; }
.tessa-gallery-wrapper .cursor-pointer { cursor: pointer; }
.tessa-gallery-wrapper .img-fluid { max-width: 100%; height: auto; }
.tessa-gallery-wrapper .mb-4 { margin-bottom: 1.5rem; }
.tessa-gallery-wrapper .row { display: flex; flex-wrap: wrap; margin-right: -15px; margin-left: -15px; }
.tessa-gallery-wrapper .col-md-4 { position: relative; width: 100%; padding-right: 15px; padding-left: 15px; flex: 0 0 33.333333%; max-width: 33.333333%; }
@media (max-width: 768px) { .tessa-gallery-wrapper .col-sm-6 { flex: 0 0 50%; max-width: 50%; } }

/* Lightbox Styles */
.tessa-gallery-wrapper .mylightbox, .tessa-gallery-wrapper .myVideoLightBox { display: none; position: fixed; top: 0; left: 0; width: 100%; height: 100%; background-color: rgba(0, 0, 0, 0.85); z-index: 99999; align-items: center; justify-content: center; }
.tessa-gallery-wrapper .mylightbox.showLightbox, .tessa-gallery-wrapper .myVideoLightBox.showVideoLightbox { display: flex; }
.tessa-gallery-wrapper .lightboxWrapper { position: relative; max-width: 900px; width: 90%; }
.tessa-gallery-wrapper .lightbox_close { position: absolute; top: -40px; right: -5px; cursor: pointer; filter: brightness(0) invert(1); }
.tessa-gallery-wrapper .photo_slider_images { width: 100%; height: auto; max-height: 75vh; object-fit: contain; }
.tessa-gallery-wrapper .photo_slider_title { color: #fff; text-align: center; margin-top: 10px; padding: 5px; font-size: 1rem; }
.tessa-gallery-wrapper .nav_slider { margin-top: 15px; }
.tessa-gallery-wrapper .nav_slider .slick-slide { padding: 0 5px; }
.tessa-gallery-wrapper .nav_slider_images { cursor: pointer; width: 100px; height: 65px; object-fit: cover; border: 2px solid transparent; opacity: 0.6; transition: opacity 0.3s ease, border-color 0.3s ease; }
.tessa-gallery-wrapper .nav_slider .slick-current .nav_slider_images { border-color: #fff; opacity: 1; }
.tessa-gallery-wrapper .videobox { position: relative; }
.tessa-gallery-wrapper .videobox::after { content: '\25B6'; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); font-size: 50px; color: white; text-shadow: 0 0 15px rgba(0,0,0,0.7); pointer-events: none; transition: all 0.3s ease; }
.tessa-gallery-wrapper .gallery-thumbnail-item:hover .videobox::after { transform: translate(-50%, -50%) scale(1.2); }
.tessa-gallery-wrapper .embed_code { width: 90vw; max-width: 1200px; height: 0; padding-bottom: 50.625%; /* 16:9 aspect ratio */ position: relative; }
.tessa-gallery-wrapper .embed_code iframe { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }