/* Masonry Portfolio Pro — styles */

.mpp-gallery-wrap {
	width: 100%;
	min-width: 0;
	box-sizing: border-box;
}

/* Elementor flex containers (Editor V4): o widget é flex item. Como o grid tem
   largura intrínseca 0 (minmax(0,1fr) / column-count), o flex item encolhe até
   os gaps (~48px) e os itens colapsam para 0×0. width:100% faz o flex-basis
   (auto) ler a largura total. Especificidade baixa de propósito: a largura
   custom do Elementor (.elementor-element-ID) continua sobrescrevendo. */
.elementor-widget-masonry_portfolio_pro,
.elementor-widget-masonry_portfolio_pro .elementor-widget-container {
	min-width: 0;
	width: 100%;
}

/* ── Grid ──────────────────────────────────────────────────────────────────── */

/* ── Masonry via CSS columns (sem JS de layout — robusto no editor Elementor) ─ */
.mpp-grid {
	width: 100%;
	min-width: 0;
	min-height: 1px;
	position: relative;
}

.mpp-item {
	position: relative;
	width: 100%;
	margin-bottom: var(--mpp-gap, 16px);
	break-inside: avoid;
	-webkit-column-break-inside: avoid;
	aspect-ratio: var(--mpp-ratio, 1.7778);
	box-sizing: border-box;
	overflow: hidden;
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}



@media (max-width: 480px) {
	.mpp-grid { column-count: 1; }
}

.mpp-item:hover {
	transform: translateY(-2px);
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.2);
	z-index: 2;
}

/* ── Thumbnail ─────────────────────────────────────────────────────────────── */

.mpp-item-link {
	display: block;
	width: 100%;
	height: 100%;
	position: relative;
	text-decoration: none;
}

.mpp-thumbnail {
	position: absolute;
	inset: 0;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	transition: transform 0.4s ease;
}

.mpp-item:hover .mpp-thumbnail {
	transform: scale(1.04);
}

.mpp-no-thumb {
	background-color: #1a1a1a;
}

/* ── Overlay ───────────────────────────────────────────────────────────────── */

.mpp-overlay {
	position: absolute;
	inset: 0;
	background: var(--mpp-overlay-bg, rgba(0, 0, 0, 0.65));
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	padding: 16px;
	opacity: 0;
	transition: opacity 0.3s ease;
	text-align: center;
	gap: 6px;
}

.mpp-item:hover .mpp-overlay {
	opacity: 1;
}

.elementor-editor-active .mpp-item-link,
.elementor-editor-preview .mpp-item-link,
.mpp-gallery-wrap.mpp-is-editor .mpp-item-link {
	pointer-events: none;
}

.elementor-editor-active .mpp-item:hover,
.elementor-editor-preview .mpp-item:hover,
.mpp-gallery-wrap.mpp-is-editor .mpp-item:hover {
	transform: none;
	box-shadow: none;
	z-index: auto;
}

.elementor-editor-active .mpp-item:hover .mpp-thumbnail,
.elementor-editor-preview .mpp-item:hover .mpp-thumbnail,
.mpp-gallery-wrap.mpp-is-editor .mpp-item:hover .mpp-thumbnail {
	transform: none;
}

.elementor-editor-active .mpp-item:hover .mpp-overlay,
.elementor-editor-preview .mpp-item:hover .mpp-overlay,
.mpp-gallery-wrap.mpp-is-editor .mpp-item:hover .mpp-overlay {
	opacity: 0;
}

.elementor-editor-active .mpp-lightbox,
.elementor-editor-preview .mpp-lightbox,
.mpp-gallery-wrap.mpp-is-editor .mpp-lightbox {
	display: none !important;
}

.mpp-gallery-wrap.mpp-is-editor .mpp-item {
	margin-bottom: 0 !important;
}

.mpp-overlay-client {
	display: block;
	color: var(--mpp-overlay-txt, #fff);
	font-size: 0.75rem;
	font-weight: 400;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	opacity: 0.8;
}

.mpp-overlay-name {
	display: block;
	color: var(--mpp-overlay-txt, #fff);
	font-size: 1rem;
	font-weight: 600;
	line-height: 1.3;
}

/* ── Play icon ─────────────────────────────────────────────────────────────── */

.mpp-play-icon {
	position: absolute;
	bottom: 10px;
	right: 10px;
	width: 36px;
	height: 36px;
	opacity: 0.8;
	pointer-events: none;
	transition: opacity 0.2s ease;
}

.mpp-item:hover .mpp-play-icon {
	opacity: 0;
}

.mpp-play-icon svg {
	width: 100%;
	height: 100%;
}

/* ── Loader (infinite scroll) ──────────────────────────────────────────────── */

.mpp-loader {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 32px;
	gap: 8px;
}

.mpp-loader-dot {
	display: inline-block;
	width: 10px;
	height: 10px;
	border-radius: 50%;
	background: currentColor;
	opacity: 0.3;
	animation: mpp-pulse 1.2s ease-in-out infinite;
}

.mpp-loader-dot:nth-child(2) { animation-delay: 0.2s; }
.mpp-loader-dot:nth-child(3) { animation-delay: 0.4s; }

@keyframes mpp-pulse {
	0%, 80%, 100% { opacity: 0.3; transform: scale(0.8); }
	40%            { opacity: 1;   transform: scale(1); }
}

.mpp-loader.mpp-hidden {
	display: none;
}

/* ── Lightbox ──────────────────────────────────────────────────────────────── */

.mpp-lightbox {
	display: none;
	position: fixed;
	inset: 0;
	z-index: 99999;
	background: rgba(0, 0, 0, 0.92);
	align-items: center;
	justify-content: center;
}

.mpp-lightbox.mpp-lightbox-open {
	display: flex;
}

.mpp-lightbox-close {
	position: absolute;
	top: 20px;
	right: 24px;
	background: none;
	border: none;
	color: #fff;
	font-size: 28px;
	cursor: pointer;
	line-height: 1;
	padding: 4px 8px;
	opacity: 0.8;
	transition: opacity 0.2s;
	z-index: 2;
}

.mpp-lightbox-close:hover {
	opacity: 1;
}

.mpp-lightbox-inner {
	width: 90vw;
	max-width: 1200px;
	max-height: 90vh;
	display: flex;
	align-items: center;
	justify-content: center;
}

.mpp-lightbox-content {
	width: 100%;
}

/* Vimeo iframe */
.mpp-lightbox-content .mpp-video-wrapper {
	position: relative;
	width: 100%;
	height: 0;
}

.mpp-lightbox-content .mpp-video-wrapper iframe {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	border: none;
}

/* Photo lightbox */
.mpp-lightbox-content img.mpp-lightbox-img {
	display: block;
	max-width: 100%;
	max-height: 90vh;
	margin: 0 auto;
	object-fit: contain;
}

/* ── Empty state ───────────────────────────────────────────────────────────── */

.mpp-empty {
	padding: 32px;
	text-align: center;
	opacity: 0.6;
}

/* ── Responsive ────────────────────────────────────────────────────────────── */

@media (max-width: 768px) {
	.mpp-overlay-name { font-size: 0.875rem; }
}
